|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
04.02.2015, 15:18 | #1 |
Пользователь
Регистрация: 24.05.2008
Сообщений: 64
|
Перестановка частей текста в строках в обратном порядке. Макрос.
Здравствуйте, уважаемые форумчане!
Для работы периодически скачиваю с сайта Россвязи таблицы с ресурсом нумерации российских операторов связи. Проблема в том, что в поле "Регион" неудобно представлена информация, т.е. в начале часто идёт название населённого пункта, затем, через разделитель "|" - название района, и только в конце строки область, край или республика, также отделенные друг от друга символом "|". Пример: Андреевка |Касторенский |Курская область Апатиты |Мурманская область Для сортировки по регионам лучше, когда в начале строки находится область, край или республика, приходится менять "части" региона в обратном порядке, чтобы сначала шла область или республика, затем район и в конце - населенный пункт (если он есть, может быть просто область без разделителей, или только область и район). Максимальное количество частей региона - 4 с тремя разделителями. Для решения этой задачи использую разделение текста по столбцам и затем формулой собираю части в обратном порядке. Из за разного количества частей последние попадают в разные столбцы, приходится в формуле проверять ячейки на пустые строки, убирать лишние пробелы, формула получается громоздкой, а строк в реальных файлах сотни тысяч. Формула: Код:
А знаний не хватает, если кому не в тягость - посмотрите, возможно ли реализовать мою "хотелку"? |
04.02.2015, 15:50 | #2 |
Новичок
СтарожилДжуниор
Регистрация: 05.02.2008
Сообщений: 9,487
|
Код:
Программисты - это люди, решающие проблемы, о существовании которых Вы не подозревали, методами, которых Вы не понимаете
|
04.02.2015, 15:52 | #3 |
Пользователь
Регистрация: 24.05.2008
Сообщений: 64
|
Спасибо, Игорь!
Пойду проверять.... |
04.02.2015, 15:56 | #4 |
Новичок
СтарожилДжуниор
Регистрация: 05.02.2008
Сообщений: 9,487
|
проверяйте на этом
Программисты - это люди, решающие проблемы, о существовании которых Вы не подозревали, методами, которых Вы не понимаете
|
04.02.2015, 15:59 | #5 |
Пользователь
Регистрация: 24.05.2008
Сообщений: 64
|
Спасибо, Игорь!
Проверил, отлично работает! Отправил на Яндекс-деньги благодарность. Последний раз редактировалось VictorK; 04.02.2015 в 16:07. |
05.02.2015, 09:05 | #6 |
Старожил
Регистрация: 05.12.2007
Сообщений: 4,180
|
Можно проще:
Код:
Чем шире угол зрения, тем он тупее.
Последний раз редактировалось SAS888; 05.02.2015 в 09:10. |
05.02.2015, 09:46 | #7 |
Новичок
СтарожилДжуниор
Регистрация: 05.02.2008
Сообщений: 9,487
|
SAS888,
+ поменять местами, 1-й и последний, 2-й и предпоследний,... и согласен - упростить-таки можно Код:
Программисты - это люди, решающие проблемы, о существовании которых Вы не подозревали, методами, которых Вы не понимаете
Последний раз редактировалось IgorGO; 05.02.2015 в 09:52. |
05.02.2015, 10:54 | #8 |
Старожил
Регистрация: 05.12.2007
Сообщений: 4,180
|
IgorGO
А что, предлагаемый мной макрос что-то не так делает? Зачем лишние вычисления? Встроенная в Excel функция "StrReverse" работает "шустро"...
Чем шире угол зрения, тем он тупее.
|
05.02.2015, 11:42 | #9 |
Новичок
СтарожилДжуниор
Регистрация: 05.02.2008
Сообщений: 9,487
|
Однако...
StrReverse напрашивался и я с этого начинал решать эту задачу, но когда увидел, что не могу прочитать результат)) отказался от затеи а тут чистая философия - "отрицание отрицания" Красиво! что еще сказать? у кого-то видел в подписи: я не программист, я только учусь... вот уже 30 лет!
Программисты - это люди, решающие проблемы, о существовании которых Вы не подозревали, методами, которых Вы не понимаете
|
05.02.2015, 13:35 | #10 |
Пользователь
Регистрация: 24.05.2008
Сообщений: 64
|
IgorGO, SAS888
Ещё раз благодарю за помощь! Буду использовать все три UDF по очереди! |
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
перестановка байтов в обратном порядке с++ | Niklitel | Помощь студентам | 1 | 17.03.2014 09:10 |
Рекурсия (печать строки введенного текста в обратном порядке) | Tokar_1 | Общие вопросы C/C++ | 7 | 13.04.2012 11:22 |
Перестановка гласных букв в обратном порядке | fenix163 | Помощь студентам | 22 | 01.03.2011 00:58 |
Перестановка символов в обратном порядке. | Zeronim | Помощь студентам | 2 | 28.06.2010 14:05 |
Перестановка чисел в массиве в обратном порядке | Student117 | Assembler - Ассемблер (FASM, MASM, WASM, NASM, GoASM, Gas, RosAsm, HLA) и не рекомендуем TASM | 3 | 22.10.2009 06:14 |