Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 18.02.2013
Сообщений: 4

Поиск в таблице из TEdit c разделителями ";"

18.02.2013, 10:45. Показов 1501. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.

Не обращаясь на форум накодил 2000 строк кода и столкнулся с проблемой, с которой точно самоучке не справиться.

Имеется TAdvStringGrid и TEdit:
C++
1
2
3
4
5
6
7
for (int Row_Count=1;Row_Count<Form1->AdvStringGrid->RowCount;Row_Count++)
    {
     if (AnsiPos(Edit1->Text,AdvStringGrid->Cells[2][Row_Count])!=0)
       {
       _кусок_кода_
       }
     }
Хочется сделать так, чтобы в Edit1 можно было вставлять множество строк поиска, разделяя их ";".
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.02.2013, 10:45
Ответы с готовыми решениями:

Сформировать текст из строки с разделителями и отсортировать его по количеству символов меж разделителями
Ввести массив символов разделителей с заданным количеством символов и массив строк текста, содержащий неизвестное заранее количество строк....

поиск подстроки между разделителями
нужна помощь :) есть строка &quot; 00.00 Name: TEXT' name...] &quot; мне нужно получить из этой строки TEXT искал в интернете,...

Поиск целых чисел в строке с разделителями
Добрый день! Есть такие строки в базе данных: 1||2||3||4 12||23||34||4512 Выполняю в них поиск для фильтрации, в массив...

5
6 / 6 / 1
Регистрация: 01.06.2012
Сообщений: 107
18.02.2013, 11:28
Кстати с дуру можно написать и 10000 строк, два дня назад только сотрудник на стажеровке парсинг лога делал, на 700 строк кода, потом дал ему задание переделать используя циклы 100, потом использовать процедуры БД, 20 строк.
Если тебя парсинг строки интерисует то вот
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
AnsiString t="раз;два;три";
AnsiString t2="";
int y;
while (t.Length()>0)
{
y=t.Pos(";");
if (y!=0)
{
t2=t.SubString(0, y-1);
ShowMessage(t2);
t= t.SubString((t2).Length()+2, t.Length()-t2.Length());
}
else
{
 ShowMessage(t);
 t="";
}
}
Добавлено через 3 минуты
Цитата Сообщение от mate26 Посмотреть сообщение
Здравствуйте.

Не обращаясь на форум накодил 2000 строк кода и столкнулся с проблемой, с которой точно самоучке не справиться.

Имеется TAdvStringGrid и TEdit:

Хочется сделать так, чтобы в Edit1 можно было вставлять множество строк поиска, разделяя их ";".
А прокоментируй код, как я понял есть некая таблица, заполненная из чего то, и там пытаешь по гриду сделать поиск...
Если заполнение из базы данных, то алгоритм в корне неверный
1
0 / 0 / 0
Регистрация: 18.02.2013
Сообщений: 4
18.02.2013, 15:16  [ТС]
Цитата Сообщение от proleha Посмотреть сообщение
А прокоментируй код, как я понял есть некая таблица, заполненная из чего то, и там пытаешь по гриду сделать поиск...
Если заполнение из базы данных, то алгоритм в корне неверный
Там таблица (достается из екселя, сам екселевский файл уничтожается)
время |название|длительность|
нужно выделить строку содержащую подстроку в названии, условие поиска может быть как одно, так и множество, а создавать ещё один edit (или ещё множество), как сами понимаете не вариант.
0
6 / 6 / 1
Регистрация: 01.06.2012
Сообщений: 107
18.02.2013, 15:26
Цитата Сообщение от mate26 Посмотреть сообщение
Там таблица (достается из екселя, сам екселевский файл уничтожается)
время |название|длительность|
нужно выделить строку содержащую подстроку в названии, условие поиска может быть как одно, так и множество, а создавать ещё один edit (или ещё множество), как сами понимаете не вариант.
Так где именно поиск проиходит, в файле эксель или в таблице былдара.
Я так понимаю, в таблице которую загрузили в одном поле будет несколько полей но разделённые символами, и по этим полям надо осуществлять поиск.
Если я правильно понял, а у меня два варианта как я понял:
1. понимаешь, хоть что это за обход будет, тоесть обходим не просто всю таблицу а ещё распарсиваем строку и сравниваем.
А разбор строки на подстроки я выше привёл. Тоесть в обход общего массива вставляешь разбор строки.
2. у тебя поле для ввода данных поиска, через точку запятую к примеру, то есть сначала создаёшь массив распарсив edit, используя код выше, и делаем поиск сравнивая необходимые поля.

В любом случае всё некрасиво.
1
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33400 / 21510 / 8236
Регистрация: 22.10.2011
Сообщений: 36,908
Записей в блоге: 12
18.02.2013, 15:29
Лучший ответ Сообщение было отмечено volvo как решение

Решение

mate26,
C++
1
2
3
4
5
6
7
8
9
10
11
    String s = L"раз раз раз;два;три";
    std::auto_ptr<TStringList> MyList(new TStringList()); // или просто TStringList *MyList = new TStringList(); + delete
    MyList->Delimiter = ';';
    MyList->DelimitedText =
       String("\"") + StringReplace(s, ";", "\";\"", TReplaceFlags() << rfReplaceAll) + "\""; // Оборачиваем строки кавычками
 
    for(int i = 0; i < MyList->Count; i++)
    {
        // Тут работаешь со строками по отдельности, через MyList->Strings[i]
        // Как? Тебе видней, что надо делать со строками...
    }
Если не сделать "оборачивания" в кавычки - о строка разобьется не только по символу, занесенному в Delimiter, но и по пробелу...
1
0 / 0 / 0
Регистрация: 18.02.2013
Сообщений: 4
19.02.2013, 07:12  [ТС]
UI, Во! То что надо! Спасибо огромное!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.02.2013, 07:12
Помогаю со студенческими работами здесь

Поиск дублей в большой строке с разделителями в List<string>
Есть текстовый файл следующей структуры: &quot;SOMETEXT&quot;;&quot;ID_NUMBER&quot;;&quot;SOMETEXT&quot;; Пример: &quot;РСЧ 111222333444555666...

Поиск заполнение ВСЕХ TEdit'ов
Помогите пожалуйста. Есть TPageControl, на нем динамически созданы вкладки (количество может быть разное), на вкладках панели, на них...

Линейный поиск в неупорядоченной таблице без барьера, двоичный поиск, поиск в двоичном дереве
Помогите пожалуйста написать программу, которая позволяет подсчитать, сколько раз в текстовом файле(ах) встретилось каждое из слов,...

Поиск по части наименования в таблице и перевод курсора в соответствующую область в другой таблице
Добрый день. Есть файл, в нем на листе Label_base вызывается по кнопке форма. Далее задуман такой алгоритм: - юзер вводит в...

Поиск записей в одной таблице, где значения ключевого поля не совпадают с полем в другой таблице
Имеется Access XP, надо создать запрос для поиска записей в таблице ТОВАРЫ,где значения ключевого поля (Артикул) не совпадают со значениями...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Данные берутся из. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru