![]() |
|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
![]() |
|
|
Опции темы | Поиск в этой теме |
![]() |
#1 |
Пользователь
Регистрация: 20.11.2008
Сообщений: 66
|
![]()
Не могу организовывать на вба,логику понимаю,что нужно проверять по словам,количеству пробелов,учет ковычек,но мне очень нужен один макрос,который сможет допустим в ячейке есть запись: ООО "Государственное Акредитованное учреждение инженерной техники и прочего производства",или
ЗАО "Консалтинговая фирма "ЭРБИС",или организационно правовая форма может так же отсутствовать,например "Консалтинговая фирма "ЭРБИС",нужно преобразовать макросом эти поля, чтобы они стали в такой форме: ООО "ГАУИТИП" ЗАО "КФ ЭРБИС" "КФ ЭРБИС"? Последний раз редактировалось Clockgen; 13.09.2010 в 14:30. |
![]() |
![]() |
![]() |
#2 |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,858
|
![]()
Обязательно макрос, или подойдёт формула (пользовательская функция)?
Выкладывайте пример файла - что есть, и что надо получить. Чем больше будет вариантов - тем точнее будет макрос формировать краткие названия. |
![]() |
![]() |
![]() |
#3 |
Пользователь
Регистрация: 20.11.2008
Сообщений: 66
|
![]()
Вот он,файл,там где наименование организации,где слишком длинные названия нужно сделать сокращенно как описано выше,т.е. абревиатурами,наверно пользовательскими формулами не обойтись((
а вручную все исправлять-это всю жизнь угробить можно(( Пример.zip |
![]() |
![]() |
![]() |
#4 |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,858
|
![]()
Вот вам пользовательская функция:
Проверяйте корректность работы самостоятельно (на тех 3 примерах из первого поста всё работает правильно) Обратите внимание на формулу: Код:
PPS: Надеюсь, на других листах формулу напишете самостоятельно. А вот и весь код пользовательской функции: Код:
|
![]() |
![]() |
![]() |
#5 |
Пользователь
Регистрация: 20.11.2008
Сообщений: 66
|
![]()
Вау,щас проверим)
|
![]() |
![]() |
![]() |
#6 |
Пользователь
Регистрация: 20.11.2008
Сообщений: 66
|
![]()
У меня еще просьба,вы наверно обратили внимание на примере который я кинул,там адреса стоят в неправильной форме: 123456,Москва,Коломенская ул,16...,а можно как нибудь сделать чтобы адрес преобрел идеальную форму: 123456, г. Москва, ул. Коломенская, д.16??? А то есть некоторые адреса именно в такой форме((
|
![]() |
![]() |
![]() |
#7 | |
Программист VBA
СуперМодератор
Регистрация: 13.07.2008
Сообщений: 6,858
|
![]() Цитата:
Но сложно - слишком много вариантов написания надо учесть. На форуме есть пример такого макроса - поищите, может, и найдёте. |
|
![]() |
![]() |
![]() |
#8 |
Пользователь
Регистрация: 20.11.2008
Сообщений: 66
|
![]()
Скажите а как можно сделать чтобы моментом перенести все преобразованные строки на место длинных навзваний,а то не получается?
Вот например от длинной сроки я преобразовал в краткое название,а тебе краткое название в этой же книге надо перенести на место длинного названия,ексель ругается что используется циклическая сслыка(( |
![]() |
![]() |
![]() |
#9 |
Участник клуба
Регистрация: 16.05.2010
Сообщений: 1,249
|
![]()
Копировать, выделить диапазон вставки, меню Правка-Спецвставка-Значения.
Подходит? |
![]() |
![]() |
![]() |
#10 |
Пользователь
Регистрация: 20.11.2008
Сообщений: 66
|
![]()
нет не подходит,а как можно сделать допустим,я выделил диапазон преобразованных из формул ячеек,т.е в них стоит формула,и зафиксировать эти значения чтобы в поле формула,была не формула а значение?
|
![]() |
![]() |
![]() |
|
Опции темы | Поиск в этой теме |
![]() |
||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
преобразование | Dimarik | Общие вопросы .NET | 2 | 20.04.2010 20:57 |
как разделить значения ячеек по формату ячеек? | ARIRAN | Microsoft Office Excel | 6 | 11.12.2009 15:30 |
Преобразование в С++ | Davlet M | Помощь студентам | 3 | 03.10.2009 14:30 |
макрос - подсчитать для каждой строки кол-во ячеек с «+», кол-во ячеек с «-» | Vadim_abs | Microsoft Office Excel | 36 | 14.07.2009 12:08 |