» Главная
eXcode.ru » Статьи » Базы данных
» Новости
» Опросы
» Файлы
» Журнал



Пользователей: 0
Гостей: 23





Работа со строками в MS Access




Автор: Dmitry Shakhov

Откровенно говоря, возможности для работы со строками в MSA небольшие и приходится писать собственные функции. О них и речь...

Поиск последнего символа в строке, например, последней точки в имени файла для определения расширения или последнего слэша в пути к файлу для определения имени файла в пути.


′Вызов функции
MsgBox FndSmb(".","main.html")
′Сама функция
Public Function FndSmb(smb As String, stroka As String) As Long
Dim a As Long
Dim b As Long
a = 1
While a > 0
b = a
a = InStr(a + 1, stroka, smb)
Wend
FndSmb = b
End Function


Замена символа или последовательности символов, чем-то похоже на одноименную функцию в РНР. Пришлось написать, когда возникла необходимость в использовании формул, задаваемых пользователем. Проблема была в том, что внутри кода разделитель мантиссы запятая, а вот для фукнции Eval нужна точка. В итоге получилась гораздо более функциональная вещь.
P.S. Начиная с версии 2000 в MSA есть функция replace(). Так что можете пользоваться ею.


′Вызов функции
MsgBox str_replace(",",".","9,9*10,17")
′Сама функция
Public Function str_replace(s1 As String, s2 As String, s As String) As String
Dim n1 As Long
Dim n2 As Long
Dim v1 As String
Dim v2 As String
Dim v3 As String

v3 = s
n2 = 1
n1 = InStr(n2, s, s1)

If n1 > 0 Then
Do
v1 = Mid(v3, 1, n1 - 1)
v2 = Mid(v3, n1 + Len(s1), Len(v3) - n1)
v3 = v1 & s2 & v2
n2 = n1 + Len(s2)
n1 = InStr(n2, v3, s1)
Loop Until n1 < 1
End If

str_replace = v3
End Function


Более сложная функция для получения элемента из строки с разделителями. Возникла из задачи, когда в одном поле таблицы оказались данные, которые необходимо было разнести по разным столбцам.
Опять же в РНР такая функция есть (split), а вот в MSA нет.


′Вызов функции
MsgBox ExpandStr("Waw;2347859;dfskgdkf",";",2) ′2347859
′Сама функция
Public Function ExpandStr(stroka As String, Razdel As String, numpos As Long)
Dim n1 As Long
Dim s1 As String
Dim v1 As String
Dim v2 As String
Dim v3 As String
Dim i As Long

v3 = stroka
s1 = Razdel
n1 = InStr(1, v3, s1)
i = 0

If n1 > 0 Then
Do
v1 = Mid(v3, 1, n1 - 1) ′возвращает слово до поисковой строки
v2 = Mid(v3, n1 + Len(s1), Len(v3) - n1) ′возвращает слово после поисковой строки
v3 = v2 ′склейка
n1 = InStr(1, v3, s1) ′выполняем новый поиск подстроки
i = i + 1
Loop Until n1 < 1 Or i >= numpos ′если такой подстроки нет, то обрываем поиск
End If
If n1 < 1 And i < numpos Then
ExpandStr = v2
Else
ExpandStr = v1
End If
End Function
К началу статьи





Добавил: LedWormДата публикации: 2005-07-16 20:19:39
Рейтинг статьи:3.00 [Голосов 5]Кол-во просмотров: 49848

Комментарии читателей

Всего комментариев: 1720

2017-08-19 18:02:48
Randalldyell
[url=http://bit.ly/21LrAQb]НАРУЧНЫЕ ЧАСЫ «Socany»[/url]

[url=http://bit.ly/21LrAQb][img]http://s018.radikal.ru/i520/1708/d7/cdd85f8740ec.png[/img][/url]


[url=http://bit.ly/21LrAQb][img]http://s019.radikal.ru/i634/1703/80/511fb7c108bc.png[/img][/url]

2017-08-19 12:35:47
vElenarof
Наш сервис предоставляет настоящие лайки на фотографии заказчиков, которые готовы платить за качество.

Именно для этого мы и набираем удалённых сотрудников, которые будут выполнять работу, то есть ставить лайки и зарабатывать за это деньги.

Чтобы стать нашим удалённым сотрудником и начать ставить лайки, зарабатывая при этом 45 рублей за 1 поставленный лайк,

Вам достаточно просто зарегистрироваться на нашем сервисе. > www.oplata-vklike.tk <

Вывод заработанных средств ежедневно в течении нескольких минут.

2017-08-18 05:24:20
Semensqp
[url=http://pultseo.ru]ПРОГОНЫ ПО ПРОФИЛЯМ[/url]

[url=http://interpult-s.ru][img]http://s14.radikal.ru/i187/1703/6c/7958bbd8b978.png[/img][/url]

[url=http://pultseo.ru]регистрация в каталогах фирм[/url]


=Inter=

2017-08-18 05:24:20
JeffreyGub
[url=http://vest-best.vsemaykishop.ru]Все майки[/url]
[url=http://vest-best.vsemaykishop.ru][img]http://s41.radikal.ru/i093/1708/b8/662d3e3603cf.png[/img][/url]

2017-08-18 03:05:55
Randalldyell
[url=http://bit.ly/21LrAQb]Часы «Socany»[/url]

[url=http://bit.ly/21LrAQb][img]http://s018.radikal.ru/i520/1708/d7/cdd85f8740ec.png[/img][/url]


[url=http://bit.ly/21LrAQb][img]http://s019.radikal.ru/i634/1703/80/511fb7c108bc.png[/img][/url]

2017-08-18 00:36:43
CharlesDiunc
[url=http://bit.ly/2rztidG]Вы знаете, что такое идеальная прелюдия?[/url]


[url=http://lezoff.ru]Интимные Украшения[/url]
[url=http://cplccp.ru/dH4N]Моментальное возбуждающее средство для женщин[/url]






~er~

2017-08-17 18:33:29
DadgilTanda
ADLENS - регулируемые очки

[url=http://kshop2.biz/6MHleC][img]http://s019.radikal.ru/i609/1707/a8/8fe006f20887.jpg[/img][/url]

Вы можете сами настроить диоптрии под свое зрение для каждого глаза индивидуально

[url=http://kshop2.biz/6MHleC][img]http://s019.radikal.ru/i634/1703/80/511fb7c108bc.png[/img][/url]






[url=http://bit.ly/2oQUzUu]ВЫДАВАЙ МИКРОЗАЙМЫ С ГАРАНТИРОВАННОЙ ДОХОДНОСТЬЮ ОТ 192% ДО 265% ГОДОВЫХ И ЗАБУДЬ О ФИНАНСОВЫХ ПРОБЛЕМАХ[/url]


=xxx$$=

2017-08-08 20:09:10
DadgilTanda
Табамекс - средство от курения

[url=http://kshop2.biz/JhD8mO][img]http://s019.radikal.ru/i625/1707/28/ecd160f1812b.jpg[/img][/url]

Убирает тягу к сигаретам. Избавляет от психологической зависимости. Подавляет желание покурить при алкогольном опьянении.

[url=http://kshop2.biz/JhD8mO][img]http://s019.radikal.ru/i634/1703/80/511fb7c108bc.png[/img][/url]


[url=http://bit.ly/2oQUzUu]ВЫДАВАЙ МИКРОЗАЙМЫ С ГАРАНТИРОВАННОЙ ДОХОДНОСТЬЮ ОТ 192% ДО 265% ГОДОВЫХ И ЗАБУДЬ О ФИНАНСОВЫХ ПРОБЛЕМАХ[/url]


=xxx$$=

2017-08-08 01:07:54
CharlesDiunc
[url=http://bit.ly/2rztidG]Секс как в первый раз[/url]


[url=http://lezoff.ru]Вибраторы[/url]
[url=http://cplccp.ru/dH4N]Моментальное возбуждающее средство для женщин[/url]






~er~

2017-08-07 19:25:26
Semenzgw
[url=http://pultseo.ru]РЕГИСТРАЦИИ ПРОФИЛЕЙ[/url]

[url=http://interpult-s.ru][img]http://s61.radikal.ru/i174/1703/f7/267a1884ebf1.png[/img][/url]

<a href=https://post-seo.blogspot.ru>адвордс фишки</a>


=Inter=
Ваше имя: *
Текст записи: *
Имя:

Пароль:



Регистрация

Какую музыку вы предпочитаете?
Techno
11% (29)
Rap
10% (26)
Rock
48% (126)
Trance
10% (27)
Pop
7% (17)
house
5% (13)
Классическую
7% (19)
Я не слушаю музыку
2% (4)

Проголосовало: 261
Разведение программистов, к сожалению, связано с большими первоначальными затратами. Вам понадобятся:
- персональный компьютер с процессором не ниже Реntium II;
- стол и стул;
- пепельница;
- большое количество сарделек и пиво для прикармливания;
- кофейная чашечка вместимостью 0,5 л.
Рейтинг: 8.3/10 (3)
Посмотреть все анекдоты