Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для SenkoL
1 / 1 / 1
Регистрация: 04.05.2013
Сообщений: 47

Парсинг строки - возможна ли оптимизация кода?

19.04.2014, 23:09. Показов 1030. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток уважаемые форумчане!

Требуется распарсить строку из БД на 3 составляющие для последующего составления запроса.
В принципе код написан, все работает, но может найдутся профи, которые укажут на ошибки и помогут написать более оптимальный код

Пример строки, получаемой в переменную из ADOQuery - "г. Вологда, ул. Мира, д. 34, кв. 56";
Из этой строки требуется вытащить в отдельные переменные город, улицу и дом соответственно.

То, что получилось за вечерней чашечкой ..чая (Код тестировал на едитах, не обессудьте):

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
       //Вместо едита будет ADOQuery->FieldByName("name_cell")->AsAnsiString;
       AnsiString address = Edit1->Text; 
       // далее объявим и иници-ем пер. address2 для 
       //восстановления перем. address, чтобы не писать длин. строку 
       //кода ADOQuery->FieldByName("name_cell")->AsAnsiString еще раз..
      
       AnsiString address2 = Edit1->Text; 
 
    int index = address.Pos("д. ");
    String house = address.Delete(1,index+2);
    int len = house.Length();
    int index2 = house.Pos(",");
    house = house.Delete(index2,len);
    address = address2;
 
    index = address.Pos("ул. ");
    String street = address.Delete(1,index+3);
    len = street.Length();
    index2 = street.Pos(",");
    street = street.Delete(index2,len);
    address = address2;
 
    index = address.Pos("г. ");
    String city = address.Delete(1,index+2);
    len = city.Length();
    index2 = city.Pos(",");
    city = city.Delete(index2,len);
    address = address2;
 
    Edit2->Text = city;    // вместо едитов будут переменные для динамического запроса
    Edit3->Text = street;
    Edit4->Text = house;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.04.2014, 23:09
Ответы с готовыми решениями:

Оптимизация кода, возможна ли?
Добрый день друзья. Подскажите, реально ли оптимизировать данный код? public partial class Form1 : Form { public...

Возможна ли оптимизация
Есть скрипт <?php class Item { public $name = 'Battle Ship'; public $defence = 5000; public $attack = 150; }

Составление палиндрома из букв строки: оптимизация кода
Здравствуйте! Опять задача со Дистанционной подготовки: https://informatics.msk.ru/mod/statements/view3.php?id=11403&chapterid=112422...

4
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,399
Записей в блоге: 3
24.04.2014, 21:37
Я бы так распарсил, но более чем уверен - тут тоже много чего соптимизировать можно

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
void __fastcall TForm4::Button1Click(TObject *Sender)
{
  const String aaa = "г. Новосибирск, ул. 1905 г., д. 15, кв. 123";
  TStringList * list = new TStringList();
  Label1->Caption = aaa;
  ExtractStrings(TSysCharSet() << ',',TSysCharSet(), aaa.c_str(), list);
  for(int i = 0; i < list->Count; i++)
   {
     TEdit *Ed;
     switch(i)
      {
        case 0 : Ed = Edit1; break;
        case 1 : Ed = Edit2; break;
        case 2 : Ed = Edit3; break;
        case 3 : Ed = Edit4; break;
      }
     String s = list->Strings[i].Trim();
     s.Delete(1,s.Pos(".")+1);
     Ed->Text = s;
   }
  delete list;
}
Миниатюры
Парсинг строки - возможна ли оптимизация кода?  
1
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,399
Записей в блоге: 3
24.04.2014, 22:00
Еще оптимизировал...
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void __fastcall TForm4::Button1Click(TObject *Sender)
{
  const String aaa = "г. Новосибирск, ул. 1905 г., д. 15, кв. 123";
  TStringList * list = new TStringList();
  Label1->Caption = aaa;
  ExtractStrings(TSysCharSet() << ',',TSysCharSet(), aaa.c_str(), list);
  for(int i = 0; i < list->Count; i++)
   {
     int j = i + 1;
     dynamic_cast<TEdit*>(FindComponent(String().sprintf(L"Edit%d", j)))->Text =
                        list->Strings[i].Delete(1,list->Strings[i].Pos(".")+1);
   }
  delete list;
}
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33395 / 21505 / 8236
Регистрация: 22.10.2011
Сообщений: 36,901
Записей в блоге: 12
24.04.2014, 22:04
XE+:
C++
1
2
3
4
5
6
7
8
9
#include <StrUtils.hpp>
 
    String s = L"г. Новосибирск, ул. 1905 г., д. 15, кв. 123";
    TStringDynArray arr(SplitString(s, ","));
    for (int i = 0; i < arr.Length; i++)
    {
        static_cast<TEdit*>(FindComponent(String().sprintf(L"Edit%d", i + 1)))->Text =
            RightStr(arr[i], arr[i].Length() - arr[i].Pos("."));
    }
1
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,399
Записей в блоге: 3
24.04.2014, 22:38
UI, спасибо.
Только я бы "для красоты" приписал
C++
1
RightStr(arr[i], arr[i].Length() - arr[i].Pos(".")).Trim()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.04.2014, 22:38
Помогаю со студенческими работами здесь

Архиватор данных - возможна ли оптимизация программы?
Привет! На С++ делаю конвертер видео в различные форматы. На входе несколько выбранных видеофайлов, на выходе столько же...

Оптимизация методом Ньютона (нахождение точки минимума). Оптимизация кода
MATLAB только начал осваивать. Попытался реализовать нахождение точки минимума методом Ньютона для функции 2*X12 - X1*X2 + 3*X22 -...

Оптимизация кода. Замер времени выполнения части кода.
Доброе утро. Есть желание посмотреть сколько времени занимает выполнение какого-то блока кода/отдельной функции или процедуры/программы...

Парсинг. Оптимизация
написав парсер самой страницы и перейдя к запросам этих страниц впал в некое уныние от цифр. 130гб за 1.2м страниц такие виды...

Возможна ли проверка кода и его запуск в инете?
В общем, я сижу с планшета и мне нужно учиться программировать на с++, к сожалению, ноутбука нет. Есть ли сайты, позволяющие написать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru