rdkit.Chem.PropertyMol module

class rdkit.Chem.PropertyMol.PropertyMol((object)self)

Bases: Mol

allows rdkit molecules to be pickled with their properties saved.

>>> import os
>>> import pickle
>>> from rdkit import RDConfig
>>> m = Chem.MolFromMolFile(os.path.join(RDConfig.RDCodeDir, 'Chem', 'test_data/benzene.mol'))
>>> m.GetProp('_Name')
'benzene.mol'

by default pickling removes properties:

>>> m2 = pickle.loads(pickle.dumps(m))
>>> m2.HasProp('_Name')
0

Property mols solve this:

>>> pm = PropertyMol(m)
>>> pm.GetProp('_Name')
'benzene.mol'
>>> pm.SetProp('MyProp','foo')
>>> pm.HasProp('MyProp')
1
>>> pm2 = pickle.loads(pickle.dumps(pm))
>>> Chem.MolToSmiles(pm2)
'c1ccccc1'
>>> pm2.GetProp('_Name')
'benzene.mol'
>>> pm2.HasProp('MyProp')
1
>>> pm2.GetProp('MyProp')
'foo'
>>> pm2.HasProp('MissingProp')
0

Property mols are a bit more permissive about the types of property values:

>>> pm.SetProp('IntVal',1)

That wouldn’t work with a standard mol

but the Property mols still convert all values to strings before storing:

>>> pm.GetProp('IntVal')
'1'

This is a test for sf.net issue 2880943: make sure properties end up in SD files:

>>> import tempfile, os
>>> fn = tempfile.NamedTemporaryFile(suffix='.sdf', delete=False).name
>>> w = Chem.SDWriter(fn)
>>> w.write(pm)
>>> w=None
>>> with open(fn,'r') as inf:
...   txt = inf.read()
>>> '<IntVal>' in txt
True
>>> try:
...   os.unlink(fn)
... except Exception:
...   pass

The next level of that bug: does writing a depickled propertymol to an SD file include properties:

>>> fn = tempfile.NamedTemporaryFile(suffix='.sdf', delete=False).name
>>> w = Chem.SDWriter(fn)
>>> pm = pickle.loads(pickle.dumps(pm))
>>> w.write(pm)
>>> w=None
>>> with open(fn,'r') as inf:
...   txt = inf.read()
>>> '<IntVal>' in txt
True
>>> try:
...   os.unlink(fn)
... except Exception:
...   pass

Constructor, takes no arguments

C++ signature :

void __init__(_object*)

__init__( (object)self, (str)pklString) -> None :

C++ signature :

void __init__(_object*,std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >)

__init__( (object)self, (str)pklString, (int)propertyFlags) -> None :

C++ signature :

void __init__(_object*,std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >,unsigned int)

__init__( (object)self, (Mol)mol [, (bool)quickCopy=False [, (int)confId=-1]]) -> None :

C++ signature :

void __init__(_object*,RDKit::ROMol [,bool=False [,int=-1]])

SetProp((Mol)self, (str)key, (str)val[, (bool)computed=False]) None :

Sets a molecular property

ARGUMENTS:
  • key: the name of the property to be set (a string).

  • value: the property value (a string).

  • computed: (optional) marks the property as being computed.

    Defaults to False.

C++ signature :

void SetProp(RDKit::ROMol,std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >,std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > [,bool=False])