你好,我正在尝试将文件disp.txt转换为:
116 C 0.12 -0.91 0.39 -0.40 0.31 0.85 -0.66 -0.18 -0.22
117 O 0.00 -0.02 0.00 -0.05 0.05 0.12 -0.57 -0.26 -0.29
116 C -0.03 -0.04 0.00 0.01 0.09 0.19 -0.71 -0.21 -0.26
117 O -0.14 0.88 -0.45 0.47 -0.33 -0.79 0.57 0.16 0.19到disp.mol:
vibration 1
0.12 -0.91 0.39
0.0 -0.02 0.0
vibration 2
-0.4 0.31 0.85
-0.05 0.05 0.12
vibration 3
-0.66 -0.18 -0.22
-0.57 -0.26 -0.29
vibration 4
-0.03 -0.04 0.00
-0.14 0.88 -0.45
vibration 5 ...我使用open(‘displ.txt’,'w')作为f打开disp.txt文件: 使用line= f.readlines()在行中读取 用x分隔数据行: numbers = x.split() 然后添加vib1.append(Numbers2)、vib2.append并将它们存储在vib1=[]、vib2=[]等中。
当我需要将我以disp.mol格式存储的数据时,我的问题就出现了。使用下面的代码,我可以从前两行获得前三次振动的输出,但我不知道如何在接下来的两行上执行相同的循环(以及是否有更多的2N行)。我也不知道如何对每个振动进行编号。如果能提供任何帮助,我们将不胜感激。
with open('disp.mol', 'w') as thisfile:
thisfile.writelines('vibration')
thisfile.writelines('\n')
for x in range (0, 2):
vib_one = str(vib1[x]) + ' ' + str(vib2[x]) + ' ' + str(vib3[x])
thisfile.writelines(vib_one)
thisfile.writelines('\n')
thisfile.writelines('vibration')
thisfile.writelines('\n')
for x in range (0, 2):
vib_two = str(vib4[x]) + ' ' + str(vib5[x]) + ' ' + str(vib6[x])
thisfile.writelines(vib_two)
thisfile.writelines('\n')
thisfile.writelines('vibration')
thisfile.writelines('\n')
for x in range (0, 2):
vib_three = str(vib7[x]) + ' ' + str(vib8[x]) + ' ' + str(vib9[x])
thisfile.writelines(vib_three)
thisfile.writelines('\n')输出:
vibration
0.12 -0.91 0.39
0.0 -0.02 0.0
vibration
-0.4 0.31 0.85
-0.05 0.05 0.12
vibration
-0.66 -0.18 -0.22
-0.57 -0.26 -0.29发布于 2016-11-02 18:06:53
以下是一种方法:
with open('disp.txt') as f, open('disp.mol','w') as out:
vibration = 1
for line in f:
line1 = line.split()
line2 = next(f).split() # also get next line
for i in range(2,len(line1),3):
out.write('vibration {}\n'.format(vibration))
out.write(' '.join(line1[i:i+3])+'\n')
out.write(' '.join(line2[i:i+3])+'\n')
vibration += 1输出:
vibration 1
0.12 -0.91 0.39
0.00 -0.02 0.00
vibration 2
-0.40 0.31 0.85
-0.05 0.05 0.12
vibration 3
-0.66 -0.18 -0.22
-0.57 -0.26 -0.29
vibration 4
-0.03 -0.04 0.00
-0.14 0.88 -0.45
vibration 5
0.01 0.09 0.19
0.47 -0.33 -0.79
vibration 6
-0.71 -0.21 -0.26
0.57 0.16 0.19https://stackoverflow.com/questions/40386544
复制相似问题