rdkit.Chem.SaltRemover module

class rdkit.Chem.SaltRemover.SaltRemover(defnFilename=None, defnData=None)

Bases: object

StripMol(mol, dontRemoveEverything=False)
>>> remover = SaltRemover(defnData="[Cl,Br]")
>>> len(remover.salts)
1
>>> mol = Chem.MolFromSmiles('CN(C)C.Cl')
>>> res = remover.StripMol(mol)
>>> res is not None
True
>>> res.GetNumAtoms()
4

Notice that all salts are removed: >>> mol = Chem.MolFromSmiles(‘CN(C)C.Cl.Cl.Br’) >>> res = remover.StripMol(mol) >>> res.GetNumAtoms() 4

Matching (e.g. “salt-like”) atoms in the molecule are unchanged: >>> mol = Chem.MolFromSmiles(‘CN(Br)Cl’) >>> res = remover.StripMol(mol) >>> res.GetNumAtoms() 4

>>> mol = Chem.MolFromSmiles('CN(Br)Cl.Cl')
>>> res = remover.StripMol(mol)
>>> res.GetNumAtoms()
4

Charged salts are handled reasonably: >>> mol = Chem.MolFromSmiles(‘C[NH+](C)(C).[Cl-]’) >>> res = remover.StripMol(mol) >>> res.GetNumAtoms() 4

Watch out for this case (everything removed): >>> remover = SaltRemover() >>> len(remover.salts)>1 True >>> mol = Chem.MolFromSmiles(‘CC(=O)O.[Na]’) >>> res = remover.StripMol(mol) >>> res.GetNumAtoms() 0

dontRemoveEverything helps with this by leaving the last salt: >>> res = remover.StripMol(mol,dontRemoveEverything=True) >>> res.GetNumAtoms() 4

but in cases where the last salts are the same, it can’t choose between them, so it returns all of them: >>> mol = Chem.MolFromSmiles(‘Cl.Cl’) >>> res = remover.StripMol(mol,dontRemoveEverything=True) >>> res.GetNumAtoms() 2

defnFilename = '/scratch/RDKit_git/Data/Salts.txt'