python程序实现输入化学式求分子量

从键盘输入一个纯净物的化学式,输出其分子量,结果保留3位小数。输入占1行;输出占1行。

9dfa0e5b68814bb8adc67e5b879e6ca6.png

def sum(element_counts, elements_dict):
    total_weight = 0
    for element, count in element_counts.items():
        total_weight += elements_dict[element] * count
    return total_weight

def get_molecular_weight(formula):
    # 定义element_counts作为字典来存储元素及其数量
    element_counts = {}
    # 定义一个栈用于存储开括号的位置
    stack = []

    # 定义元素符号和对应的原子量
    elements_dict = {
        'H': 1.007,
        'He': 4.002,
        'Li': 6.938,
        'Be': 9.012,
        'B': 10.806,
        'C': 12.0096,
        'N': 14.006,
        'O': 15.999,
        'F': 18.998,
        'Ne': 20.1797,
        'Na': 22.989,
        'Mg': 24.305,
        'Al': 26.981,
        'Si': 28.084,
        'P': 30.973,
        'S': 32.059,
        'Cl': 35.45,
        'K': 39.0983,
        'Ca': 40.078,
        'Sc': 45.0,
        'Ti': 47.9,
        'V': 50.9,
        'Cr': 51.9961,
        'Mn': 54.938,
        'Fe': 55.845,
        'Co': 58.9,
        'Ni': 58.7,
        'Cu': 63.6,
        'Zn': 65,
    }

    i = 0
    while i < len(formula):
        if formula[i].isupper():
            element = formula[i]
            i += 1
            while i < len(formula) and formula[i].islower():
                element += formula[i]
                i += 1
            count = ''
            while i < len(formula) and (formula[i].isdigit() or formula[i] == '/'):
                count += formula[i]
                i += 1
            if count == '':
                count = '1'
            element_counts[element] = int(count)
        elif formula[i] == '(':
            stack.append(i)
            i += 1
        elif formula[i] == ')':
            start = stack.pop()
            end = i
            num = ''
            i += 1
            while i < len(formula) and (formula[i].isdigit() or formula[i] == '/'):
                num += formula[i]
                i += 1
            if num == '':
                num = '1'
            sub_formula = formula[start + 1:end]
            sub_weight = get_molecular_weight(sub_formula)
            for j in range(start + 1, end):
                if formula[j].isupper():
                    element_counts[formula[j]] *= int(num)
            for element, count in sub_weight.items():
                element_counts[element] = element_counts.get(element, 0) + count
        else:
            i += 1

    return element_counts

# 获取输入的化学式
m = input()
# 去除空格
list0 = ''.join(m.split())
# 定义元素的原子量字典
elements_dict = {
    'H': 1.007,
    'He': 4.002,
    'Li': 6.938,
    'Be': 9.012,
    'B': 10.806,
    'C': 12.0096,
    'N': 14.006,
    'O': 15.999,
    'F': 18.998,
    'Ne': 20.1797,
    'Na': 22.989,
    'Mg': 24.305,
    'Al': 26.981,
    'Si': 28.084,
    'P': 30.973,
    'S': 32.059,
    'Cl': 35.45,
    'K': 39.0983,
    'Ca': 40.078,
    'Sc': 45.0,
    'Ti': 47.9,
    'V': 50.9,
    'Cr': 51.9961,
    'Mn': 54.938,
    'Fe': 55.845,
    'Co': 58.9,
    'Ni': 58.7,
    'Cu': 63.6,
    'Zn': 65,
}
# 调用get_molecular_weight函数计算分子量
molecular_weight = sum(get_molecular_weight(list0), elements_dict)
print('%.3f' % molecular_weight)

 测试运行结果:

802ac3c96aa3448899419404da687e24.png

注意,某些复杂化学式如络合物等的分子式无法计算。 

Since 6.0.0 6.6.0 + 增加由精确分子量搜索分子式小工具(在“工具”菜单中选择) * 改进最简式结果,现在总是把碳(C)元素放在最前,其余原子按原子序数排列 * 界面上一些细节的改进 - 为适应 Window 7 及后续版本,本程序最小化后不再在任务栏隐藏,直接点击主窗口上的关闭按钮将直接退出程序 - 去掉了精简模式窗口 - 去掉了窗口“总在前面”选项 6.5.0 + 内置所有天然同位素精确质量,用户指定某种同位素的质量数时,如果恰好是天然同位素,则用内置的精确同位素质量代替用户输入的质量数(仅当原子量使用“精确值”或“最高丰度精确值”时有效)。比如如果输入{13C},则使用原子量13.0034(之前的版本直接使用13.0000) + 内置一个计算不饱和度的小工具(工具-->计算不饱和度) + 增加一个独立运行的分子式格式化工具,可以将剪贴板中的文字按一般分子式的要将数字变成上下标 * 用户指定某种同位素时,可以不指定质量数,程序将根据“使用原子量”选项选用最高丰度的同位素的精确质量或者质量数进行计算。比如输入{H},程序将选用原子量1.0078进行计算(之前的版本将报错) * 改进了最简式结果,现在总是把碳(C)元素放在最前,氧(O)元素放在最后,更符合一般人的阅读习惯 * 大量程序界面细节的改进,现在可以在各种列表和表格中正常显示分子式,不再需要安装任何字体文件,速度也更快 * 批量计算部分重写,现在这个功能有了界面 * 主菜单上一些功能增加了快捷键,程序中个别快捷键修改 * 程序全面支持UNICODE - RTF格式历史记录合并到“历史记录”中,原RTF格式历史记录选项不再有效 - 修正一个前端显示时主窗口可能遮住对话窗口的BUG 6.4.1 + 增加批量计算功能,在“工具”菜单中,一些过长的分子式可以从文件中导入防止显示速度过慢 - 修正一处同位素质量数显示问题 - 修正统计基团时潜在的问题 * 改进历史记录存盘文件样式 6.4.0 + 增加一个选项,可以选择不即时给出结果,以加快输入速度 - 修正在输入很长分子式时光标移出输入框的问题 * 改写内核,大幅提高大小写自动判断速度,尤其含有大量缩写时 * 改写内核,提高计算速度 * 将氨基酸缩写改为更简洁形式,提高计算速度 * 一些细节的优化,提高效率 6.3.0 + 缩写设定中缩写值首字母为"_"(英文下划线)时将忽略此项 + 默认设定下加入20种氨基酸残基的缩写(每种去掉一分子水) - 修正某对话框中的错别字 - 修正缩写设定对话框中不能输入"="的问题 - 修正缩写设定中缩写为空时造成的程序错误 - 修正安装后在C盘根目录下留下CHEM_4.TTF文件的问题 - 修正卸载后不能删除快速启动栏快捷方式的问题 * 增强监视剪贴板的兼容性:自动忽略复制到剪贴板中的分子式中前后的空格 * 缩写设定对话框和原子量设定对话框中按ESC可以直接关闭 6.2.2 - 修正某些情况下重复运行程序窗口不能弹出的问题 - 修正有时程序退出时会弹出调试对话框的问题 6.2.1: - 修正窗口隐藏时检测到剪贴板变化不能弹出的问题 6.2.0: + 增加两个选项:是否启用历史记录功能,如果禁用,可以加快计算速度,默认开启 + 增加设置窗口的快捷键为F10 + 自定义原子量窗口增加快速功能 + 增加展开缩写的功能,在编辑菜单中 - 修正输入分子式长度有限制的bug * 程序界面细小改进:在关于窗口点击版本号弹出ChangeLog * 程序细节的改进 6.1.1: + 增加分子量计算器主页 - 修正分子式括号中角标显示不正确的问题 * 程序细节的改进 6.1.0: + 增加一套最大丰度同位素精确原子量表 - 修正“质量数”原子量表为丰度最大同位素质量数 - 修正RTF历史窗口一处显示的问题 - 修正程序启动时不能装入原子量选项的bug * 改进了核心代码,提高效率 * 程序细节的改进 6.0.0: + 新增支持计算化学式中某些特定的基团的质量分数 + 自动保存用户设置在INI文件中 + 保存历史记录支持纯文本以及RTF两种格式 + 将元素统计结果复制到剪贴板时将有更多选择 + 简易模式窗口可以自动隐藏 - 彻底解决了当化学式中存在缩写基团时可能会发生的问题 * 程序启动时自动判断是否安装“Chemistry Numbers”字体以采取不同的显示策略,在没有字体的情
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_走廊灯关上

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值