|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
|
Опции темы | Поиск в этой теме |
12.03.2009, 19:45 | #1 |
Форумчанин
Регистрация: 02.02.2009
Сообщений: 842
|
Реализация функций Rexx по работе со строками в VBA
ALL: Очень часто в форуме поднимается вопрос деления строки на отдельные слова/части. Уже много раз на него давали ответ, но к сожалению, по какой-то причине люди не проводят поиск по раним сообщениям. В FIDO вообще-то такое поведение наказуемое, но это к слову... Я решил внести свой не большой вклад в тему, и раньше чем планировал выложить первые две первые процедуры по сабжу. При грамотном их использовании можно творить чудеса. :) Замечание, предложения, комментарии приветствоваться.
Код:
С уважением, Алексей.
|
12.03.2009, 19:55 | #2 |
Форумчанин
Регистрация: 02.02.2009
Сообщений: 842
|
Пример использования:
Код:
Смещение - рассчитанное ранее смещение от края листа.
С уважением, Алексей.
|
12.03.2009, 20:33 | #3 |
Форумчанин
Регистрация: 30.01.2008
Сообщений: 314
|
несколько проще это реализуется..
(Вы как раз не воспользовались поиском ) Код:
s - текстовая строка n - количество слов в s sr - i-е слово в s(или "", если слов меньше i) |
12.03.2009, 21:41 | #4 | |
Форумчанин
Регистрация: 02.02.2009
Сообщений: 842
|
Цитата:
Обновленные версии процедур: Код:
С уважением, Алексей.
|
|
13.03.2009, 11:45 | #5 |
Форумчанин
Регистрация: 30.01.2008
Сообщений: 314
|
так чуть "правильнее"
Код:
|
13.03.2009, 16:21 | #6 | |
Форумчанин
Регистрация: 02.02.2009
Сообщений: 842
|
Цитата:
И подправить: sr = Split(Application.Trim(str), " ")(number - 1), на word = Split(Application.Trim(str), " ")(number - 1) Странно у меня до этого без строки word="" вчера выдавал нуль, если слова под таким номером нет. А сегодня правильно, выдает пустую строку.
С уважением, Алексей.
|
|
14.03.2009, 13:08 | #7 |
Форумчанин
Регистрация: 30.01.2008
Сообщений: 314
|
я ж и имел ввиду, что "правильнее" объявлять типы явно!
|
15.03.2009, 13:32 | #8 |
Форумчанин
Регистрация: 02.02.2009
Сообщений: 842
|
Как (уже) многолетний пользователь Rexx считаю, что типы данных - зло. В Rexx'се они отсутствую как класс, что значительно расширяет возможности, а конструкции делают более красивыми, повышается читабельность листинга. В общем одни плюсы. :)))
Вот последняя версия процедур: Код:
С уважением, Алексей.
|
15.03.2009, 21:51 | #9 |
Форумчанин
Регистрация: 30.01.2008
Сообщений: 314
|
может быть код будет и красивше, но работать будет дольше..
я выбираю эффективность. |
16.03.2009, 04:52 | #10 | |
Старожил
Регистрация: 05.12.2007
Сообщений: 4,180
|
tae1980
Цитата:
Чем шире угол зрения, тем он тупее.
|
|
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Реализация функций из библиотеки stdio.h | Blade | Общие вопросы C/C++ | 9 | 23.11.2008 12:35 |
Реализация функций синхронизации потоков. | натка | Помощь студентам | 1 | 03.01.2008 15:26 |
Проблеммы с использованием функций работы со строками Copy и Pos | Soso | Общие вопросы Delphi | 13 | 09.08.2007 16:01 |
нужна помощь по работе с строками файлов... | Ruffian | Общие вопросы Delphi | 9 | 15.11.2006 16:05 |