当前位置: 首页 > article >正文

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_` 开头。


http://www.kler.cn/a/542917.html

相关文章:

  • 接口测试Day12-持续集成、git简介和安装、Gitee远程仓库、jenkins集成
  • HalconDotNet 基础操作
  • 【深度学习】多目标融合算法(四):多门混合专家网络MMOE(Multi-gate Mixture-of-Experts)
  • 12c及以后 ADG主备切换
  • 深度学习|表示学习|Instance Normalization 全面总结|26
  • 【人工智能】Python中的序列到序列(Seq2Seq)模型:实现机器翻译
  • 黑马Redis详细笔记(实战篇---短信登录)
  • 电脑出现蓝屏英文怎么办?查看修复过程
  • 【物联网】电子电路基础知识
  • RocketMQ、RabbitMQ、Kafka 的底层实现、功能异同、应用场景及技术选型分析
  • 华为openEuler部署docker
  • CCFCSP第34次认证第一题——矩阵重塑(其一)
  • DeepSeek应用——与word的配套使用
  • 活动预告 | 解锁 Excel 新境界 —— AI 技术赋能下的数据分析超级引擎!
  • 【C++高并发服务器WebServer】-17:阻塞/非阻塞和同步/异步、五种IO模型、Web服务器
  • 【Windows/C++/yolo开发部署04】使用CLI 和 python进行推理
  • 理解UML中的四种关系:依赖、关联、泛化和实现
  • 美团智能外呼机器人意图训练全流程
  • docker发布自己的镜像
  • VSCode Cline 插件快速接入 DeepSeek API,提升本地深度学习效率
  • 讲解一下SpringBoot的RPC连接
  • Redis常见数据结构
  • 利用Python和SQLite进行数据处理与优化——从数据库操作到高级数据压缩
  • 除了try...catch,还有其他处理异步错误的方法吗?
  • clickhouse replicatedmergetree 恢复
  • 自制游戏——斗罗大陆