3

私はPythonとコンピューティング言語全般にかなり慣れていません。テキスト ファイルを開いて、その内容をネストされた辞書に保存したいと考えています。これまでの私のコードは次のとおりです。

inputfile = open("Proj 4.txt", "r")
for line in inputfile:
    line = line.strip()
    print line
NGC = {}

inputfile.close()

辞書に追加操作を使用する必要があることはわかっていますが、続行する方法がわかりません。テキストファイルのコピーは次のとおりです。

NGC0224
Name: Andromeda Galaxy
Messier: M31
Distance: 2900
Magnitude: 3.4
NGC6853
Name: Dumbbell Nebula
Messier: M27
Distance: 1.25
Magnitude: 7.4
NGC4826
Name: Black Eye Galaxy
Messier: M64
Distance: 19000
Magnitude: 8.5
NGC4254
Name: Coma Pinwheel Galaxy
Messier: M99
Distance: 60000
Brightness: 9.9 mag
NGC5457
Name: Pinwheel Galaxy
Messier: M101
Distance: 27000
Magnitude: 7.9
NGC4594
Name: Sombrero Galaxy
Messier: M104
Distance: 50000
4

2 に答える 2

2
with open(infilepath) as infile:
  answer = {}
  name = None
  for line in infile:
    line = line.strip()
    if line.startswith("NGC"):
      name = line
      answer[name] = {}
    else:
      var, val = line.split(':', 1)
      answer[name][var.strip()] = val.strip()

テキスト ファイルで出力します。

>>> with open(infilepath) as infile:
...   answer = {}
...   name = None
...   for line in infile:
...     line = line.strip()
...     if line.startswith("NGC"):
...       name = line
...       answer[name] = {}
...     else:
...       var, val = line.split(':', 1)
...       answer[name][var.strip()] = val.strip()
... 
>>> answer
{'NGC6853': {'Messier': 'M27', 'Magnitude': '7.4', 'Distance': '1.25', 'Name': 'Dumbbell Nebula'}, 'NGC4254': {'Brightness': '9.9 mag', 'Messier': 'M99', 'Distance': '60000', 'Name': 'Coma Pinwheel Galaxy'}, 'NGC4594': {'Messier': 'M104', 'Distance': '50000', 'Name': 'Sombrero Galaxy'}, 'NGC0224': {'Messier': 'M31', 'Magnitude': '3.4', 'Distance': '2900', 'Name': 'Andromeda Galaxy'}, 'NGC4826': {'Messier': 'M64', 'Magnitude': '8.5', 'Distance': '19000', 'Name': 'Black Eye Galaxy'}, 'NGC5457': {'Messier': 'M101', 'Magnitude': '7.9', 'Distance': '27000', 'Name': 'Pinwheel Galaxy'}}
于 2013-10-16T04:55:58.740 に答える
0

このデータを辞書にマップする方法をより適切に定義する必要があります。ファイル形式を変更できますが、標準の INI ファイルとして再フォーマットするとよいでしょう。ConfigParserモジュールで読むことができます。

でも、どうしても行きたいならこの道を。ここに手っ取り早い解決策があります:

d = {}
k = ''
for line in open('Proj 4.txt'):
    if ':' in line:
        key, value = line.split(':', 1)
        d[k][key] = value.strip()
    else:
        k = line.strip()
        d[k] = {}

dict d には解析済みファイルがあります。

于 2013-10-16T04:54:03.207 に答える