Python中文
首页
教程
问答
标签
搜索
登录
注册
如何用具有特定图案的指定线条替换线条?
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我有一个文本文件如下:</p> <pre><code>geo.txt Receptor Name:I151T.B99990002_mus.pdbqt Liang Name: LIGAND 1 Using random seed: 1896818552 mode | affinity | dist from best mode | (kcal/mol) | rmsd l.b.| rmsd u.b. -----+------------+----------+---------- 1 -10.7 0.000 0.000 2 -10.4 1.859 3.037 3 -10.1 1.992 3.474 Receptor Name: I151T.B99990001_mus.pdbqt Liang Name: LIGAND 1 Using random seed: 1896818552 mode | affinity | dist from best mode | (kcal/mol) | rmsd l.b.| rmsd u.b. -----+------------+----------+---------- 1 -9.5 0.000 0.000 2 -9.4 2.083 3.784 3 -9.0 2.471 8.360 4 -9.0 1.493 3.523 </code></pre> <p>在上面的文件中,我想提取每个具有模式(Receptor Name:)的行,并将这些行与其对应的值相加。你知道吗</p> <p>我尝试过:</p> <pre><code>import os import re h=open("/Users/geoList.txt","r") for i in h: if re.match(r'\s\s\s\d+', i) or i.startswith("Receptor Name:"): print i.replace("\n","") </code></pre> <p>我得到如下输出:</p> <pre><code>Receptor Name: I151T.B99990002_mus.pdbqt 1 -10.7 0.000 0.000 2 -10.4 1.859 3.037 3 -10.1 1.992 3.474 Receptor Name:I151T.B99990001_mus.pdbqt 1 -9.5 0.000 0.000 2 -9.4 2.083 3.784 3 -9.0 2.471 8.360 4 -9.0 1.493 3.523 </code></pre> <p>但是在这里,我不知道如何将具有(Receptor Name:)的线与其各自的值连接起来。你知道吗</p> <p>例如:预期的输出文件应如下所示:</p> <pre><code>FIRST PATTERN MATCH: with corresponding values: ----------------------------------------------- Receptor Name:I151T.B99990002_mus.pdbqt 1 -10.7 0.000 0.000 Receptor Name:I151T.B99990002_mus.pdbqt 2 -10.4 1.859 3.037 Receptor Name:I151T.B99990002_mus.pdbqt 3 -10.1 1.992 3.474 SECOND PATTERN MATCH: with corresponding values ----------------------------------------------- Receptor Name: I151T.B99990001_mus.pdbqt 1 -9.5 0.000 0.000 Receptor Name: I151T.B99990001_mus.pdbqt 2 -9.4 2.083 3.784 Receptor Name: I151T.B99990001_mus.pdbqt 3 -9.0 2.471 8.360 Receptor Name: I151T.B99990001_mus.pdbqt 4 -9.0 1.493 3.523 </code></pre> <p>先谢谢</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您可以这样做(您只需要存储带有“Receptor”的行):</p> <pre><code>>>> for line in h: ... if line.startswith('Receptor Name:'): ... prefix = line ... elif re.search(r'^\s+\d', line): ... print prefix + ' ' + line.strip() </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
jupyter运行一个旧的pytorch版本
4 回答
Jupyter运行不同版本的卸载库?
9 回答
Jupyter运行指定的键盘快捷键
2 回答
Jupyter通过.local文件“逃逸”virtualenv。我该如何缓解这种情况?
10 回答
Jupyter重新加载自定义样式
7 回答
Jupyter错误:“没有名为Jupyter_core.paths的模块”
5 回答
jupyter错误:无法在随机林中将决策树视为png
9 回答
Jupyter错误'内核似乎已经死亡,它将自动重新启动'为一个给定的代码块
7 回答
Jupyter错误地用阿拉伯语和字母数字元素显示Python列表
1 回答
Jupyter隐藏数据帧索引,但保留原始样式
2 回答
Jupyter集线器:启动器中出现致命错误。。。系统找不到指定的文件
10 回答
Jupyther中相同值的相同哈希,但导出到Bigquery时不相同
6 回答
Jupy上Python的读/写访问问题
9 回答
jupy上没有模块cv
8 回答
Jupy上的排序错误
4 回答
Jupy中bqplot图形的紧凑布局
3 回答
Jupy中matplotlib plot的连续更新
2 回答
Jupy中Numpy函数的文档
2 回答
Jupy中Pandas的自动完成问题
8 回答
jupy中Qt后端的Matplotlib动画
8 回答