169 похожих чатов

Подскажите, пожалуйста. Использую fread. Если данных в какой-то

строке меньше, чем колонок, то fill=T спасёт. А вот если идёт строка, в которой полей больше чем колонок, то дополнительных колонок не добавляется. Как победить? Надо почитать csv, у которого не все колонки имеют имена, не известно сколько колонок.
Гугл по быстрому не помог(

6 ответов

10 просмотров

Возможно, эти дополнительные поля в одну колонку просто читаются? Тогда их можно разделить по своему усмотрению

Анатолий- Автор вопроса
Andrey
Возможно, эти дополнительные поля в одну колонку п...

Чтение останавливается с сообщением Stopped early on line 1002. Expected 23 fields but found 25. Consider fill=TRUE and comment.char=. Fill не помогает(

"неизвестно сколько колонок" - это какой-то плохой csv, по идее должно быть в каждой строке одинаковое число незакавыченных запятых (или какой там разделитель) можно попробовать сначала определить сколько максимально колонок в файле (построчным подсчетом запятых через средства командной строки), а потом задать colClasses для fread

Анатолий
Чтение останавливается с сообщением Stopped early...

Я с таким при помощи awk как-то справлялся.

Анатолий- Автор вопроса
Evgeniy
"неизвестно сколько колонок" - это какой-то плохой...

Попробовал. ColClasses не добавляет "лишних" колонок, если не видит данных для них в начале файла. Проблему решил написанием вручную в csv названий недостающих колонок (мда:/) и разговором с создателем csv чтобы так больше не делал. Странно, что нет готового решения "из коробки"

Анатолий
Попробовал. ColClasses не добавляет "лишних" коло...

Нет решения, потому описанный кейс не про CSV. Есть вполне себе стандарт обмена данными в формате CSV: https://tools.ietf.org/html/rfc4180 Описанный файл не подпадает под определение CSV. Within the header and each record, there may be one or more fields, separated by commas. Each line should contain the same number of fields throughout the file. Spaces are considered part of a field and should not be ignored. The last field in the record must not be followed by a comma. Код пакетов/утилит для работы с CSV пишется с опорой на стандарт. Покрыть все аномалии, а твой случай именно аномалия, не возможно.

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта