metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-11-09 08:28 pm

Адъ CSV

А напишите кто-нибудь табличку состояний CSV парсера? Т.е. последовательность символов, разделенных запятыми, в строках, разделенных \r или \r\n разбить на список списков строк. Если в строке должны быть служебные символы (т.е. запятая или \r \n) - строка обрамляется в кавычки, если внутри такой строки нужна кавычка - ставится две кавычки подряд.
На самом деле там немного сложнее, типа допустимо незначимые пробелы возле запятых, а значимыми их делают тоже через кавычки, управляющие символы <32 вроде тоже обязательно в кавычки, но это пофиг.
Вроде блин простая задачка, а каждый раз когда ее приходится делать - получаются на пару страниц конечные автоматы.

[identity profile] metaclass.livejournal.com 2009-11-09 10:03 pm (UTC)(link)
В том алгоритме на С, что ниже - добавится в выходную строку.
Вроде бы по стандарту, он должен игнорироваться, если около разделителей, а внутри строки недопустим.

[identity profile] arush-damage.livejournal.com 2009-11-09 11:44 pm (UTC)(link)
Стандарт ломало читать :)
Обработка пробелов - вообще не проблема.

[identity profile] arush-damage.livejournal.com 2009-11-09 11:46 pm (UTC)(link)
А вот про конец строки я забыл :(

[identity profile] metaclass.livejournal.com 2009-11-10 08:13 am (UTC)(link)
Вот про это я и говорю - сколько не делаю, обязательно что нибудь забуду :)