AkelPad Forum Index AkelPad
Support forum
 
 FAQFAQ   SearchSearch   MemberlistMemberlist   UsergroupsUsergroups   RegisterRegister 
 ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

Как заменить все четные запятые в строках на точки?

 
Post new topic   Reply to topic    AkelPad Forum Index -> Discussion (Russian)
View previous topic :: View next topic  
Author Message
temp1111



Joined: 26 Aug 2008
Posts: 54

PostPosted: Wed Dec 30, 2015 10:18 am    Post subject: Как заменить все четные запятые в строках на точки? Reply with quote

Есть CSV-файлы, при формировании которых десятичным разделитем сдуру поставили запятую, а так как она же и разделитель полей, то файлы теперь экспортируются в эксель неправильно. Файлы - это ценные данные с приборов, и очень нужно их реанимировать, приведя формат к правильному.

Для исправления достаточно заменить все четные запятые в каждой строке файла на точки, но я не умею писать скрипты, а регулярные выражения не катят, т.к. численные форматы полей разные.

Кто-нибудь из знатоков может срочно помочь?

Спасибо заранее и с наступающим!
Back to top
View user's profile Send private message
YuS



Joined: 15 Sep 2013
Posts: 332

PostPosted: Wed Dec 30, 2015 11:23 am    Post subject: Re: Как заменить все четные запятые в строках на точки? Reply with quote

temp1111 wrote:

Для исправления достаточно заменить все четные запятые в каждой строке файла на точки, но я не умею писать скрипты, а регулярные выражения не катят, т.к. численные форматы полей разные.

Отчего же не катят? Вы просто не совсем правильно их "готовите" (в смысле, регэкспы) Smile
Тут только требуется уточнение:
Не учитываются идущие подряд запятые, т.е. между ними должен присутствовать хотя бы один любой символ... если требуется учет таких запятых, то потребуется небольшое изменение регэкспов.
Вариант 1:
Code:
Что: (,)([^,]++)(\1)
Чем: \1\2.

- четность запятых строгая, считается независимо от перевода строки

Вариант 2:
Code:
Что: (,)([^,\n]++)(\1)
Чем: \1\2.

- четность запятых в каждой строке рассчитывается заново.
Back to top
View user's profile Send private message
temp1111



Joined: 26 Aug 2008
Posts: 54

PostPosted: Wed Dec 30, 2015 12:08 pm    Post subject: Reply with quote

Спасибо большое, все прекрасно сошлось.

Подряд идущих запятых (т.е. пустых полей), к счастью, нету. Воспользовался вариантом 2, т.к. файлы большие (по несколько МБ). Обещаю изучить регэкспы Smile

С наступающим!
Back to top
View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic    AkelPad Forum Index -> Discussion (Russian) All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


SourceForge.net Logo Powered by phpBB © 2001, 2005 phpBB Group