鱼C论坛

 找回密码
 立即注册
查看: 1833|回复: 4

[已解决]如何使用正则表达式计算相对分子质量?

[复制链接]
发表于 2018-1-25 16:41:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. s = 'C12H2O6N6'
  2. L =['C', 'H', 'O', 'N']
  3. LC = []
  4. Lint = []
  5. sint = ''

  6. for c in s:
  7.     if c in L:
  8.         LC.append(c)
  9.         Lint.append(sint)
  10.         sint = ''
  11.     else:
  12.         sint = sint + c
  13. Lint.append(sint)
  14. Lint.pop(0)
  15. print(LC)
  16. print(Lint)

  17. sum = 0
  18. d = {'C':12, 'H':1, 'O':16, 'N':14}
  19. for i in range(0,len(LC)):
  20.     sum += int(d[LC[i]]) * int(Lint[i])


  21. print(s +'的相对分子质量为:',sum)
复制代码


这是我写的用列表的方式计算相对分子质量,如果用正则表达式的方式该如何计算?为什么要用正则表达式?这是因为很多情况下都不知道分子式的具体表达式,需要使用正则表达式对其进行分块,甚至有很多个分子式在excel中,该如何计算?也就是说如何循环计算下面excel表中相对分子质量?
最佳答案
2018-1-25 20:36:55
本帖最后由 yjsx86 于 2018-1-25 20:39 编辑

分子质量是多少都忘了 只能帮到这里
  1. import re
  2. s = 'C12H2O6N6'
  3. rec = re.compile(r'([A-Z])(\d*)')
  4. print(dict(rec.findall(s)))
  5. # 结果
  6. {'C': '12', 'H': '2', 'O': '6', 'N': '6'}
复制代码
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-1-25 16:57:07 | 显示全部楼层
本帖最后由 sky 于 2018-1-25 17:08 编辑

我试试
  1. >>> a = "O12N12C6H6"
  2. >>> import re
  3. >>> p = re.compile(r"O(?P<o>\d*)N(?P<n>\d*)C(?P<c>\d*)H(?P<h>\d*)")
  4. >>> b = p.search(a)
  5. >>> b.groupdict()
  6. {'o': '12', 'n': '12', 'c': '6', 'h': '6'}
  7. >>>
复制代码


不行 有点复杂 我搞不定

可以分开写正则表达式吧
p_o = r"O(?P<o>\d*)"
p_n = r"N(?P<n>\d*)"
...
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-25 20:36:55 | 显示全部楼层    本楼为最佳答案   
本帖最后由 yjsx86 于 2018-1-25 20:39 编辑

分子质量是多少都忘了 只能帮到这里
  1. import re
  2. s = 'C12H2O6N6'
  3. rec = re.compile(r'([A-Z])(\d*)')
  4. print(dict(rec.findall(s)))
  5. # 结果
  6. {'C': '12', 'H': '2', 'O': '6', 'N': '6'}
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-1-25 20:53:18 | 显示全部楼层
yjsx86 发表于 2018-1-25 20:36
分子质量是多少都忘了 只能帮到这里

谢谢您,您说的我知道了。
我现在的问题是,如何对一串分子式进行计算相对分子质量,就像我的图片中的一样,计算单元格中的相对分子质量,这该怎么操作?
谢谢您!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-16 22:15:58 | 显示全部楼层
如果一系列的值需要计算的话有第三方表格模块的,你可以去查一下,作为化学专业的,我觉得这个还是挺有用的,有时间写写看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-17 17:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表