首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用Pandas从化学式中提取氢的数量(即从C18H36P1中提取36)

如何使用Pandas从化学式中提取氢的数量(即从C18H36P1中提取36)
EN

Stack Overflow用户
提问于 2019-05-08 00:12:44
回答 2查看 79关注 0票数 1

我希望能够在pandas数据框中创建一个新的列,它包含化学式中的氢原子的数量。从化学式C18H36P1S1中得到氢原子的数量,会得到36。化学公式是通用的,所以你不能仅仅提供确切的化学公式,在一列中有数千个。

EN

回答 2

Stack Overflow用户

发布于 2019-05-08 00:15:12

代码语言:javascript
复制
import re

REGEX = re.compile(r'H(?P<hydrogens>\d+)')
REGEX.search('C18H36P1S1').group('hydrogens')

返回:

'36'

票数 1
EN

Stack Overflow用户

发布于 2019-05-08 00:17:21

您可以使用str.extract

代码语言:javascript
复制
df = pd.DataFrame({'formula':['C18H36P1S1']})
df['No Hydrogens'] = df['formula'].str.extract('.*H(\d+)[A-Za-z].*')


    formula     No Hydrogens
0   C18H36P1S1  36
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56026639

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档