怎么使用openbabel的pybel?

文章介绍了如何安装OpenBabelGUI及其Python绑定pybel,提醒了使用pip和conda的正确命令。pybel用于处理分子数据,包括Molecule类的各种属性如atoms、charge、energy等。此外,文章还提到了SMARTS匹配功能和分子的结构操作,如加氢、去氢、局部优化等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先进行Open Babel GUI 安装:http://openbabel.org/wiki/Category:Installation


而使用pybel则需要它的python绑定:

可以使用 pip 或 conda 来安装 Open Babel 的 Python 绑定。(使用pybel)

  • 如果您使用 pip,在命令行中输入 pip install openbabel 来安装。(最新版的openbabel-3.1.1.1会报错,请规避)

  • 如果您使用 conda,在命令行中输入 conda install openbabel -c conda-forge 来安装。

请注意必须使用 from openbbel import pybel 才能import pybel

上述代码会给我画一个苯环,成功!


另外,千万不要直接使用 pip install pybel 之类的命令,这个不是openbabel的pybel,而是另一个工具包PyBEL。(含泪哭诉)


Molecule(OBMol)

Molecules有以下属性特征: atomschargedatadimenergyexactmassformulamolwtspinsssrtitle and unitcell (晶体数据)。atoms 特征提供了分子中所有Atoms的列表。data 特征返回字典对象,可用来获得和编辑与分子相关的数据 ( 是MoleculeData对象,但可当作普通的字典对象)。unitcell 特征可获得任何与分子有关的“unit cell”数据(OBUnitCell)。

Molecule

  • OBMol: 就是OB的分子,内含相应的C++方法
  • atoms: 原子对象的列表
  • charge: 分子电荷
  • conformers: 构象?返回的是c++ vector.
  • data: 返回分子一些属性信息的字典,用于构造MoleculeData.
  • dim: 返回Long型?! 的整数,0/2/3维
  • energy: 返回分子的能量
  • exactmass: 精确分子量
  • formula: 分子式
  • molwt: 分子量
  • spin: 自旋度
  • sssr: 最小环的集合(C++)
  • title: 分子名
  • unitcell: 晶胞信息,有的话.
  • addh(): 加氢
  • removeh(): 去氢
  • calcfp(fptype='FP2'): 计算指纹返回指纹对象Fingerprint.指纹类型参考全局变量
  • calcdesc(descnames=[]): 计算相应描述符, 如果不指名就会全部计算.描述符参考全局变量.
  • draw(show=True, filename=None, update=False, usecoords=False): 产生2维分子描述.show是否在屏幕显示, filename可以指定写到图像文件,后两者是否更新以及使用现有坐标.
  • localopt(forcefield='mmff94', steps=500): 局部优化,力场和优化步数.如果没有坐标会优先使用make3D().需要分子有H.
  • make3D(forcefield='mmff94', steps=50): 先产生3维坐标再调用局部优化,参数是局部优化参数.
  • write(format='smi', filename=None, overwrite=False): 将文件写到文件,格式,文件名以及是否覆盖已有文件. 如果不指名文件名, 返回文件内容的字符串.

MoleculeData(obmol)

使用ob的分子产生相应附加数据的对象(字典),其实用途不大,更常用mol.data。

>>> mol=readfile("sdf","calculatedprops.sdf").next()# (readfile is described below)

>>> print mol.molwt100.1

>>> print len(mol.atoms)

16

>>> print mol.data.keys()

{'Comment': 'Created by CDK', 'NSC': 1, 'Hydrogen Bond Donors': 3, 'Surface Area': 342.43, .... }

>>> print mol.data['Hydrogen Bond Donors']

3

>>> mol.data['Random Value']=random.randint(0,1000)# 添加一个噪音描述符

SMARTS matching

用法:Smarts(smartspattern)

Pybel 提供了一个简单的 API 用来链接 Open Babel SMARTS pattern 匹配.。A Smarts object is created, and the findall() method is then used to return a list of the matches to a given Molecule.

Here is an example of its use:

>>> mol = readstring("smi","CCN(CC)CC") # 创造一个三乙胺基团
>>> smarts = Smarts("[#6][#6]") # 匹配乙基基团
>>> print smarts.findall(mol)
[(1, 2), (4, 5), (6, 7)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

LRJ-jonas

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

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

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

打赏作者

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

抵扣说明:

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

余额充值