Как заставить csvkit распознавать длинные строки ASCII?

Я использую Ubuntu, и я скачал этот файл CSV, который file говорит мне, закодировано как:

ASCII text, with very long lines, with CRLF line terminators

Тем не менее, когда я прохожу csvcut -e ASCII datafile, Я получил:

Your file is not "utf-8" encoded. Please specify the correct encoding with the -e flag. Use the -v flag to see the complete error.

и когда я прохожу csvcut -e ASCII datafile, Я получил:

Your file is not "ASCII" encoded. Please specify the correct encoding with the -e flag.

(Ни заглавные буквы, ни копирование-вставка точного file выходной улучшает это.)


Полная ошибка (-v) выглядит так:

Traceback (most recent call last):
  File "/usr/local/bin/csvcut", line 9, in <module>
    load_entry_point('csvkit==0.9.2', 'console_scripts', 'csvcut')()
  File "/usr/local/lib/python2.7/dist-packages/csvkit-0.9.2-py2.7.egg/csvkit/utilities/csvcut.py", line 64, in launch_new_instance
    utility.main()
  File "/usr/local/lib/python2.7/dist-packages/csvkit-0.9.2-py2.7.egg/csvkit/utilities/csvcut.py", line 53, in main
    for row in rows:
  File "/usr/local/lib/python2.7/dist-packages/csvkit-0.9.2-py2.7.egg/csvkit/unicsv.py", line 51, in next
    row = next(self.reader)
  File "/usr/local/lib/python2.7/dist-packages/six.py", line 535, in next
    return type(self).__next__(self)
  File "/usr/local/lib/python2.7/dist-packages/csvkit-0.9.2-py2.7.egg/csvkit/unicsv.py", line 35, in __next__
    return next(self.reader).encode('utf-8')
  File "/usr/lib/python2.7/codecs.py", line 615, in next
    line = self.readline()
  File "/usr/lib/python2.7/codecs.py", line 530, in readline
    data = self.read(readsize, firstline=True)
  File "/usr/lib/python2.7/codecs.py", line 477, in read
    newchars, decodedbytes = self.decode(data, self.errors)
UnicodeDecodeError: 'ascii' codec can't decode byte 0xc2 in position 0: ordinal not in range(128)

1 ответ

Ваша полезная нагрузка не кодируется ни в кодировке ASCII, ни в кодировке UTF-8. Вы можете быстро найти не ASCII биты:

awk '/[^\x00-\x7F]/{ print NR ":", $0 }' data.csv | less

Вы увидите такие вещи, как Briarcliffe College�??Patchogue в эмуляторе терминала в кодировке UTF-8, предполагая, что это не файл в кодировке UTF-8. И первое предположение о кодировке? ISO 8859-1, западноевропейский. Давайте проверим:

# piping to /dev/null to suppress printing and speed up processing (printing to tty is slow)
csvcut -e iso-8859-1 data.csv >/dev/null

На этот раз без ошибок, вуаля!

Другие вопросы по тегам