Я получаю ошибку valueError в приведенном ниже коде.
ValueError('too many values to unpack',)
with open('38374657484839373636.csv') as f:
for line in f.read().split('\n'):
if line:
repo, file, pkey = line.split(",")
keys.add(pkey)
Возможный дубликат Разделить строку только по первому пробелу в python, просто используйте аргумент split(... maxsplit=n)
. А если вы хотите увидеть более сложный ответ, см. это
Спасибо, теперь понял - извиняюсь, не видел другую тему.
Самый простой способ читать CSV-файлы (и Excel-файлы тоже с pd.read_excel()
) — использовать Панды
import pandas as pd
df = pd.read_csv('38374657484839373636.csv')
df.head()
Иногда необходимо установить разделитель явно, в зависимости от того, что находится во входном файле. Например, если разделитель в вашем файле /
import pandas as pd
df = pd.read_csv('38374657484839373636.csv', delimiter='/')
df.head()
Также следите за тем, есть ли у вашего csv-файла заголовок или нет. Например.:
import pandas as pd
df = pd.read_csv('38374657484839373636.csv', delimiter='/',header=None)
df.head()
Очевидно, по крайней мере в одной из ваших строк больше двух запятых. Рассматривали ли вы возможность использования встроенного в Python модуля обработки CSV?