欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 时评 > RDKit 给3D信息缺失的sdf生成三维结构

RDKit 给3D信息缺失的sdf生成三维结构

2025/2/12 16:41:48 来源:https://blog.csdn.net/m0_55097528/article/details/145550969  浏览:    关键词:RDKit 给3D信息缺失的sdf生成三维结构

要生成包含三维结构的 SDF 文件,可以使用 RDKit 等化学信息学工具。以下是一个 Python 脚本示例,使用 RDKit 读取 SDF 文件、生成三维结构并保存。

### 安装 RDKit
如果尚未安装 RDKit,可以通过以下命令安装:

```bash
conda install -c conda-forge rdkit
```

### Python 脚本

```python
import os
from rdkit import Chem
from rdkit.Chem import AllChem

def generate_3d_structure(input_sdf, output_sdf):
    # 读取 SDF 文件
    suppl = Chem.SDMolSupplier(input_sdf)
    writer = Chem.SDWriter(output_sdf)

    for mol in suppl:
        if mol is not None:
            # 生成三维结构
            AllChem.EmbedMolecule(mol)
            AllChem.UFFOptimizeMolecule(mol)
            # 写入新的 SDF 文件
            writer.write(mol)

    writer.close()

def process_directory(directory):
    for filename in os.listdir(directory):
        if filename.endswith(".sdf"):
            input_sdf = os.path.join(directory, filename)
            output_sdf = os.path.join(directory, f"3d_{filename}")
            generate_3d_structure(input_sdf, output_sdf)
            print(f"Processed {filename} and saved to {output_sdf}")

if __name__ == "__main__":
    # 指定目录
    directory = "path/to/your/directory"
    process_directory(directory)
```

### 脚本说明

1. **generate_3d_structure**: 读取 SDF 文件,生成三维结构并保存。
2. **process_directory**: 遍历指定目录,处理所有 `.sdf` 文件。
3. **EmbedMolecule**: 生成三维坐标。
4. **UFFOptimizeMolecule**: 使用 UFF 力场优化结构。

### 使用步骤

1. 将脚本保存为 `generate_3d_structures.py`。
2. 修改 `directory` 变量为目标目录路径。
3. 运行脚本:

```bash
python generate_3d_structures.py
```

脚本会为每个 `.sdf` 文件生成一个包含三维结构的新文件,文件名以 `3d_` 开头。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com