0

zip コマンドに問題があります。私はPythonを初めて使用し、計算化学ソフトウェアGaussianからの入力と出力を操作するために使用しています。

私の問題は次のとおりです。その原子番号と対応する原子の座標を 2 つの別々のリストとして抽出し、それらをまとめて圧縮します。問題は、新しく作成された辞書は、原子番号を対応する座標に正しく関連付けながら、それらのペアの順序をシャッフルしているように見えるということです。

これは私のコードです:

 str1 = lines[best_i + count].split()
 str1 = list(filter(None, str1))
 li_atoms.append(str1[1])
 li_lines.append(str1[3] + " " + str1[4] + " " + str1[5] + "\n")

 dict_lines = dict(zip(li_lines, li_atoms))
 new_line = str1[1] + " " + str1[3] + " " + str1[4] + " " + str1[5] + "\n"
 print(li_atoms)
 print(li_lines)
 print(new_line)

最初の 4 行は、リストを作成してから圧縮する方法を示しています。これは私が得ているものです:

['6', '6', '6', '6', '6', '6', '1', '1', '1', '1', '1', '8', '1', '8', '1', '1', '8', '1', '1', '8', '1', '1']  

['-0.934843 0.899513 0.316846\n',   
'-2.190300 1.027357 -0.281071\n',   
'-2.985223 -0.106295 -0.461617\n',   
'-2.532226 -1.360236 -0.051572\n',   
'-1.273703 -1.473149 0.546850\n',   
'-0.466792 -0.350395 0.736201\n',   
'-2.544435 2.004569 -0.604798\n',     
'-3.961332 -0.002247 -0.927404\n',     
'-3.152766 -2.239891 -0.193462\n',   
'-0.912684 -2.443561 0.876875\n',   
'0.509490 -0.433361 1.204588\n',   
'-0.107548 1.983966 0.517635\n',   
'-0.544217 2.786118 0.189973\n',   
'1.956069 -1.097186 -1.539946\n',   
'0.995285 -1.167127 -1.420910\n',   
'2.137200 -0.128588 -1.433795\n',   
'2.906601 -0.987077 1.012487\n',   
'3.770505 -1.401214 1.155911\n',   
'2.616140 -1.289889 0.114737\n',   
'2.585476 1.353513 -0.478949\n',   
'1.755805 1.714987 -0.116377\n',   
'2.904746 0.753703 0.231017\n']    

{'-1.273703 -1.473149 0.546850\n': '6',   
'-2.190300 1.027357 -0.281071\n': '6',   
'-2.544435 2.004569 -0.604798\n': '1',   
'2.585476 1.353513 -0.478949\n': '8',   
'2.906601 -0.987077 1.012487\n': '8',   
'-3.961332 -0.002247 -0.927404\n': '1',   
'0.995285 -1.167127 -1.420910\n': '1',   
'3.770505 -1.401214 1.155911\n': '1',   
'-2.985223 -0.106295 -0.461617\n': '6',   
'-0.544217 2.786118 0.189973\n': '1',   
'2.616140 -1.289889 0.114737\n': '1',   
'-0.912684 -2.443561 0.876875\n': '1',   
'-2.532226 -1.360236 -0.051572\n': '6',   
'1.755805 1.714987 -0.116377\n': '1',   
'2.137200 -0.128588 -1.433795\n': '1',   
'1.956069 -1.097186 -1.539946\n': '8',   
'0.509490 -0.433361 1.204588\n': '1',   
'-3.152766 -2.239891 -0.193462\n': '1',   
'-0.934843 0.899513 0.316846\n': '6',   
'2.904746 0.753703 0.231017\n': '1',   
'-0.107548 1.983966 0.517635\n': '8',   
'-0.466792 -0.350395 0.736201\n': '6'}

そして、その辞書を上記の両方のリストと同じ順序にしたいと思います。調べてくれてありがとう。

4

1 に答える 1

1

Python 辞書には順番がありません。表示される動作は完全に正常で正しいものです。

メソッドのPython ドキュメントをdict.items()引用すると、次のようになります。

キーと値は任意の順序でリストされます。これはランダムではなく、Python の実装によって異なり、辞書の挿入と削除の履歴に依存します。

辞書とセットの順序が任意である理由を参照してください。それはなぜですか。

順序を保持する必要がある場合は、collections.OrderedDict()代わりにa を使用します。

from collections import OrderedDict

 dict_lines = OrderedDict(zip(li_lines, li_atoms))
于 2013-07-16T09:50:55.727 に答える