![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
А напишите кто-нибудь табличку состояний CSV парсера? Т.е. последовательность символов, разделенных запятыми, в строках, разделенных \r или \r\n разбить на список списков строк. Если в строке должны быть служебные символы (т.е. запятая или \r \n) - строка обрамляется в кавычки, если внутри такой строки нужна кавычка - ставится две кавычки подряд.
На самом деле там немного сложнее, типа допустимо незначимые пробелы возле запятых, а значимыми их делают тоже через кавычки, управляющие символы <32 вроде тоже обязательно в кавычки, но это пофиг.
Вроде блин простая задачка, а каждый раз когда ее приходится делать - получаются на пару страниц конечные автоматы.
На самом деле там немного сложнее, типа допустимо незначимые пробелы возле запятых, а значимыми их делают тоже через кавычки, управляющие символы <32 вроде тоже обязательно в кавычки, но это пофиг.
Вроде блин простая задачка, а каждый раз когда ее приходится делать - получаются на пару страниц конечные автоматы.
no subject
Date: 2009-11-09 09:12 pm (UTC)Поиск делимитера по позициям ломается на делимитерах внутри кавычек.
И обрабатываю я не одну строку а все строки подряд, потому что у меня может быть такое:
"test
test"
и это должно вернуться в виде одной строки внутри списка, с \r\n внутри
no subject
Date: 2009-11-09 09:44 pm (UTC)no subject
Date: 2009-11-09 09:47 pm (UTC)no subject
Date: 2009-11-09 09:49 pm (UTC)там кроме одного флага и значения предыдущего символа ничего не нужно
no subject
Date: 2009-11-09 09:55 pm (UTC)no subject
Date: 2009-11-09 09:59 pm (UTC)no subject
Date: 2009-11-09 10:03 pm (UTC)Вроде бы по стандарту, он должен игнорироваться, если около разделителей, а внутри строки недопустим.
no subject
Date: 2009-11-09 11:44 pm (UTC)Обработка пробелов - вообще не проблема.
no subject
Date: 2009-11-09 11:46 pm (UTC)no subject
Date: 2009-11-10 08:13 am (UTC)