Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> boost::tokenizer, С чем его едят? 
:(
    Опции темы
Chaos A.D.
Дата 13.4.2006, 10:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 172
Регистрация: 16.1.2005
Где: 09 RUS

Репутация: 6
Всего: 7



Вот уже часа два никак не могу разобраться с boost::tokenizer. Подскажите, какой TokenizerFunction мне выбрать, и как с ним работать, если мне нужно распарсить элементарную строку вида
Цитата

"C:/projects/qt/uic_helper/Forms/MainForm.ui"; "C:/projects/qt/uic_helper/Forms/Копия (2) MainForm.ui"; "C:/projects/qt/uic_helper/Forms/Копия MainForm.ui"

на составные части (как вы видите, на отдельные файлы)? Как мне казалось, у меня не должно было возникнуть проблем с escaped_list_separator, но не работает...

Это сообщение отредактировал(а) Chaos A.D. - 13.4.2006, 10:21
--------------------
Надо смеяться над тем, что тебя мучит, иначе не сохранишь равновесия, иначе мир сведет тебя с ума...Ken Kesey - One Flew Over The Cocoo's Nest
PM MAIL   Вверх
comcon1
Дата 13.4.2006, 14:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 838
Регистрация: 11.6.2005
Где: Москва ДАС-МГУ

Репутация: 12
Всего: 17



Ща дам пример. Погодь. Вот пример прямо из моей проги.
Парсит строку типа "12 42 67".
amount -массив unsigned
_inputlist - указатель на массив строк.
Код

    boost::char_separator<char> sep(" \n\t");       // Для BOOST - tokenizer
    tokenizer::iterator tok_it;
    tokenizer *tokens;
/* ......... */
    sep = boost::char_separator<char> (" \n\t");       // Для BOOST - tokenizer
    tokens = new tokenizer((*_inputlist)[1],sep);
    tok_it = tokens->begin(); 
    if (std::distance(tokens->begin(), tokens->end()) != 3) 
      throw 0;
    for (int j=0; j<3; ++j) {
      amount[j] = lexical_cast<unsigned>(*tok_it); 
      ++tok_it; 
    }
    delete tokens;

Добавлено @ 14:22
инициализируй separator символами ' " ',' ; '. Получишь имена файлов и пробелы. Вот.

Это сообщение отредактировал(а) comcon1 - 13.4.2006, 14:20


--------------------
PM MAIL   Вверх
chaos
Дата 14.4.2006, 07:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Серийный программист
****


Профиль
Группа: Завсегдатай
Сообщений: 2979
Регистрация: 7.7.2004
Где: Екатеринбург

Репутация: 6
Всего: 44



Цитата(Chaos A.D. @ 13.4.2006, 10:20)
Вот уже часа два никак не могу разобраться с boost::tokenizer. Подскажите, какой TokenizerFunction мне выбрать, и как с ним работать, если мне нужно распарсить элементарную строку вида
Цитата

"C:/projects/qt/uic_helper/Forms/MainForm.ui"; "C:/projects/qt/uic_helper/Forms/Копия (2) MainForm.ui"; "C:/projects/qt/uic_helper/Forms/Копия MainForm.ui"

на составные части (как вы видите, на отдельные файлы)? Как мне казалось, у меня не должно было возникнуть проблем с escaped_list_separator, но не работает...

не понял smile
на что тебе надо разбить твои строки?
на диск, путь, имя файла ?
PM WWW   Вверх
chaos
Дата 14.4.2006, 07:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Серийный программист
****


Профиль
Группа: Завсегдатай
Сообщений: 2979
Регистрация: 7.7.2004
Где: Екатеринбург

Репутация: 6
Всего: 44



вот тебе еще один пример с использованием boost::regex
Код

#include <iostream>
#include <boost/regex.hpp>
using namespace std;

int main()
{
    boost::regex r("(.+):(.+)\\/(.+\\..+)", boost::regex::perl|boost::regex::icase);
    boost::match_results<std::string::const_iterator> what;

    string s;
    char *strs[] = {"C:/projects/qt/uic_helper/Forms/MainForm.ui", 
                    "C:/projects/qt/uic_helper/Forms/Копия (2) MainForm.ui",
                    "C:/projects/qt/uic_helper/Forms/Копия MainForm.ui", NULL};
    int n = 0;
    while (strs[n])
    {
        s = strs[n++];
        cout << s.c_str() << endl;
        if (boost::regex_match(s, what, r))
            for (size_t m = 1; m < what.size(); m++)
                cout << what[m] << endl;
    }

    return 0;
}


Это сообщение отредактировал(а) chaos - 14.4.2006, 07:59
PM WWW   Вверх
comcon1
Дата 14.4.2006, 12:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 838
Регистрация: 11.6.2005
Где: Москва ДАС-МГУ

Репутация: 12
Всего: 17



Да.
Я вот тоже предпочитаю пользоваться REGEX-парсером, а когда лень составлять РЕГЕКСы --- юзаю СПИРИТ.
Но с ним на первый раз возни ОЧЕНЬ много. Зато он сразу конверсию переменных осуществляет.


--------------------
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0720 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.