Arhn - архитектура программирования

Как создать dict dicts с помощью файла csv

Я хотел бы создать словарь с ключом, являющимся первой строкой CSV-файла, и значением, являющимся словарем {первый столбец: соответствующий столбец для строки} Например, test.csv

Header1, Header2, Header3
A,       1,       10
B,       2,       20
C,       3,       30

Я использую data.drop(['Header1'], 1), чтобы удалить Header1.

Я хотел бы, чтобы результирующий дикт был:

{'Header2':{A:1, B:2, C:3},'Header3':{A:10, B:20, C:30}}

Должен ли я использовать csv.DictReader? Или массивы numpy вместо этого?


  • Вы имеете в виду {'Header2':{A:1, B:2, C:3},'Header3':{A:10, B:20, C:30}} ? 30.07.2018
  • Просто сделайте to_dict 30.07.2018
  • Если проблема решена, отметьте один из ответов как правильный 30.07.2018

Ответы:


1

Используя панд,

df = pd.read_csv(testcsv, index_col=['Header1'], sep=',\s+')
df.to_dict()

Выход:

{'Header2': {'A': 1, 'B': 2, 'C': 3}, 'Header3': {'A': 10, 'B': 20, 'C': 30}}
29.07.2018
  • Это говорит о том, что ValueError: Index Header1 недействителен? 30.07.2018
  • Попробуйте index_col=[0], потому что первый столбец csv не отображается как «Заголовок1». 30.07.2018

  • 2

    Другой пример без панд:

    import csv
    
    with open('data_all.csv', newline='') as csvfile:
        reader = csv.reader(csvfile, delimiter=',')
        dicts = {entry:{} for entry in next(reader)[1:]}
        for row in reader:
            index = 0
            for _dict in dicts.values():
                index+=1
                _dict[row[0]]=row[index]
    
        print(dicts)
    

    {' Header2': {'A': ' 1', 'B': ' 2', 'C': ' 3'}, ' Header3': {'A': ' 10', 'B': ' 20', 'C': ' 30'}}

    29.07.2018
    Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..