Я пытаюсь извлечь некоторые данные из файлов JSON, которые построены одинаково, и записать выбранные данные в новый файл JSON.
base_dir = 'mypath'
def createJsonFile() :
splitTest1 = {}
splitTest1['20mm PSL'] = []
for file in os.listdir(base_dir):
# If file is a json, construct it's full path and open it, append all json data to list
if 'json' in file:
json_path = os.path.join(base_dir, file)
json_data = pd.read_json(json_path, lines=True)
if splitTest1[file]['20mm PSL'] == to_find:
splitTest1['20mm PSL'].append({
'filename': os.path.basename(base_dir),
'triggerdata': ['rawData']['adcDump']['0B'],
'velocity': {
'imgVel': ['computedData']['particleProperties']['imgVelocity'],
'trigVel': ['computedData']['img0Properties']['coordinates']},
'coordinates': ['computedData']['img1Properties']['coordinates']})
print(len(splitTest1))
ошибка, которую я получаю: 'triggerdata': ['rawData'] ['adcDump'] ['0B'], TypeError: индексы списка должны быть целыми числами или срезами, а не str
моя цель: Создайте новый файл JSON, который представляет собой более или менее список каждого файла JSON в моей папке с данными: Имя файла, данные триггера, скорость (imgVel и trigVel), координаты.
На следующем этапе моей программы мне понадобится этот новый splitTest1 для анализа данных различных файлов.
Я новичок в Python, поэтому надеюсь найти здесь некоторую помощь. :)






Ваше значение dict недопустимо для Python.
triggerdata': ['rawData']['adcDump']['0B']
Значение не имеет никакого смысла: вы составляете список из одной строки, а затем пытаетесь проиндексировать его с помощью другой строки. Вы запросили элемент "adcDump" списка ['rawData'], но такого синтаксиса нет.
Вы не можете хранить произвольный исходный код (ваше частичное выражение), как если бы это было значение данных.
Если вам нужна помощь в создании конкретной ссылки, задайте конкретный вопрос. Пожалуйста, повторите как спросить из вступительный тур.
Проблема в этой строке
'imgVel': ['computedData']['particleProperties']['imgVelocity'],
И два, которые идут после этого. Что происходит, так это то, что вы создаете список со строкой computedData в качестве единственного элемента. А затем пытаюсь найти индекс ParticleProperties, что не имеет смысла. Вы можете индексировать список только целыми числами. Я не могу дать вам "решение", но если вы хотите, чтобы imgVel был просто списком этих строк, вы бы сделали
'imgVel': ['computedData', 'particularProperties', 'imgVelocity']