Почему я получаю эту ошибку (TypeError: объект '_io.TextIOWrapper' не подписывается) после первой итерации цикла for? - PullRequest
0 голосов
/ 15 февраля 2019

Следующий код, который я написал, запустит одну итерацию без проблем.Однако я хочу, чтобы он перебрал все значения х (которых в данном случае 8).После выполнения первого цикла, когда он переходит ко второму, я получаю сообщение об ошибке в этой строке (t = f [x] ['master_int'])

Traceback (most recent call last):
  File "Hd5_to_KML_test.py", line 16, in <module>
    t = f[x]['master_int']
TypeError: '_io.TextIOWrapper' object is not subscriptable

Так что выводятся только результаты (файл .csv и файл .kml) для BEAM0000.Я ожидал, что он будет проходить и выводить два файла для всех 8 лучей.Чего мне не хватает, почему бы не пройти через другие лучи?

import h5py
import numpy as np
import csv
import simplekml
import argparse

parser = argparse.ArgumentParser(description='Creating a KML from an HD5 file')
parser.add_argument('HD5file', type=str)
args = parser.parse_args()
HD5file = args.HD5file

f = h5py.File(HD5file, 'r')
beamlist = []
for x in f:
    t = f[x]['master_int']
    for i in range(0, len(t), 1000):
        time = f[x]['master_int'][i]
        geolat = f[x]['geolocation']['lat_ph_bin0'][i]
        geolon = f[x]['geolocation']['lon_ph_bin0'][i]
        beamlist.append([time, geolat, geolon])     
    file = x + '.csv'
    with open(file, 'w') as f:
        wr = csv.writer(f)
        wr.writerows(beamlist)      

    inputfile = csv.reader(open(file, 'r'))
    kml = simplekml.Kml()       

    for row in inputfile:
        kml.newpoint(name=row[0], coords=[(row[2], row[1])])
        kml.save(file + '.kml')

1 Ответ

0 голосов
/ 15 февраля 2019

Когда вы используете здесь контекстный менеджер:

with open(file, 'w') as f:

он переназначается на f, поэтому при попытке доступа к значению, подобному f[x], он пытается вызвать __getitem__(x) на f, который вызывает TypeError

, замените этот блок:

with open(file, 'w') as f:
    wr = csv.writer(f)
    wr.writerows(beamlist) 

на что-то вроде:

with open(file, 'w') as fileobj:
    wr = csv.writer(fileobj)
    wr.writerows(beamlist) 
...