Russian Qt Forum
Ноябрь 26, 2024, 10:45
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Общие вопросы
>
Работа с файлами
Страниц: [
1
]
2
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Работа с файлами (Прочитано 8664 раз)
kadr
Гость
Работа с файлами
«
:
Октябрь 17, 2009, 19:37 »
Всем привет, помогите мне решить такую проблему!
имеется фаил примерно такого содержания:
8203 Цикло-Прогинова драже х 21 Schering GmbH und Co. Produktions KG 6 490,97р. 490,97р. ( ВCE ГРУППЫ )
8204 Фемоден драже х 21 Schering GmbH und Co. Produktions KG 79 434,52р. 434,52р. ( ВCE ГРУППЫ )
8207 Ультрапрокт супп. ректал. х 10 Intendis Manufacturing - Италия 11 354,12р. 354,12р. ( ВCE ГРУППЫ )
Нужно выдернуть из него по отдельности- код, нименование, производителя, количество, цену и группу, для дальнейшей загрузки этого всего в MySQL.
Там куча пробелов, например в названии много пробелов, пытался решить проблему split-ом, но названия имеют разное количество пробелов, такая же ерунда и в производителе!
Посоветуйте, что нибудь!
Да в файле 3500 строк, так что работать ручками не хочется!
«
Последнее редактирование: Октябрь 17, 2009, 19:39 от kadr
»
Записан
BRE
Гость
Re: Работа с файлами
«
Ответ #1 :
Октябрь 17, 2009, 19:42 »
Поля точно пробелами разделены? может все таки табуляцией?
Можно попробовать регулярными выражениями, в качестве разделителя между полями использовать 2 и более пробелов.
Записан
kadr
Гость
Re: Работа с файлами
«
Ответ #2 :
Октябрь 17, 2009, 19:45 »
Точно пробелами, с регулярными выражениями у меня пока туговато! Может как нибуть по проще это можно сделать?
Записан
lit-uriy
Джедай : наставник для всех
Offline
Сообщений: 3880
Re: Работа с файлами
«
Ответ #3 :
Октябрь 17, 2009, 20:03 »
можно посимвольно читать, больше двух пробелов подряд - разделять
Записан
Юра.
Joss
Гость
Re: Работа с файлами
«
Ответ #4 :
Октябрь 17, 2009, 20:06 »
1,4,5,6 колонки - начинаются с цифры
7 - со скобки
2 колонка - заканчивается цифрой
Я бы парсил через IndexOf()
Записан
lit-uriy
Джедай : наставник для всех
Offline
Сообщений: 3880
Re: Работа с файлами
«
Ответ #5 :
Октябрь 17, 2009, 20:06 »
сейчас скопировал пример в текстовый редактор и увидел:
7 столбцов с фиксированными позициями:
0, 11, 54, 97, 107, 119, 132
Записан
Юра.
kadr
Гость
Re: Работа с файлами
«
Ответ #6 :
Октябрь 17, 2009, 20:12 »
Я пытался читать посимвольно, но тоже не то, я не могу заставить программу понимать что там больше 2 пробелов!
while (!file_r.atEnd())
{
str = file_r.readLine().trimmed();
i = 0;
while (i != str.length())
{
if (str.at(i) != ' ')
{
str2.append(str.at(i)).trimmed();
}
else
{
while (str.at(i) ==' ')
{
i++;
}
i--;
}
i++;
}
От того что там не будет пробелов вообще мне не лучше, как то надо заделить данные, а без пробелов вообще получиться одна большая строки и что мне с ней делать! Было бы замечательно если бы за место пробелов там где нужно поставить знак какойнибудь, например |, можно было бы тогда воспользоваться split-ом, но он мне и в названиях товара, где есть пробел, соответсвенно наставил этих знаков!
Записан
kadr
Гость
Re: Работа с файлами
«
Ответ #7 :
Октябрь 17, 2009, 20:16 »
Цитата: Joss от Октябрь 17, 2009, 20:06
1,4,5,6 колонки - начинаются с цифры
7 - со скобки
2 колонка - заканчивается цифрой
Я бы парсил через IndexOf()
А по подробнее можно про это! как это можно осуществить, indexOf() возвращает индекс символа или подстроки если они найдены! Как мне это поможет!
Да во второй колонке не все названия заканчиваются цифрой, а 7 начинается не только со скобки!
«
Последнее редактирование: Октябрь 17, 2009, 20:18 от kadr
»
Записан
Joss
Гость
Re: Работа с файлами
«
Ответ #8 :
Октябрь 17, 2009, 20:31 »
А в Excel не засунуть это?
В некоторых редакторах есть выделение столбцов, в том же MSVC - не поможет?
Вообще вопрос надо перенести, это не Qt, это алгоритмы.
А автор выдает неполную информацию, поэтому помочь невозможно. Полноценный пример в студию...
Записан
kadr
Гость
Re: Работа с файлами
«
Ответ #9 :
Октябрь 17, 2009, 20:37 »
Дело в том что я в QT совсем недавно, поэтому много не знаю! Разве QT работает с exele? Какой информации не хватает? Я же говорю, что надо из файла текстового выдернуть определнные данные, вот и интересуюсь, как это можно сделать, просто сам никак не пойму как сделать!
Записан
Joss
Гость
Re: Работа с файлами
«
Ответ #10 :
Октябрь 17, 2009, 20:49 »
1. Тема не для этой ветки, это не Qt.
2. Excel... там есть VusialBasic, можно легко обработать формы, сконвертировать так, как нужно.
3. Информации не хватает - файла самого. Вы же приводите пример, к которому дают конкретные алгоритмы, оказывается есть множество исключений и эти алгоритмы не подходят.
Совет - если нет возможности алгоритмизировать, ищите обходные пути. Может файл вообще в Excel можно получить, может вручную отформатировать.
Записан
BRE
Гость
Re: Работа с файлами
«
Ответ #11 :
Октябрь 17, 2009, 21:21 »
Да все просто:
Код
C++ (Qt)
QStringList
lst
=
str.
split
(
QRegExp
(
"
\\
s{2,}"
)
)
;
qDebug
(
)
<<
lst
;
Вывод:
("8203", "Цикло-Прогинова драже х 21", "Schering GmbH und Co. Produktions KG", "6", "490,97р.", "490,97р.", "( ВCE ГРУППЫ )")
Записан
kadr
Гость
Re: Работа с файлами
«
Ответ #12 :
Октябрь 18, 2009, 15:59 »
Цитата: BRE от Октябрь 17, 2009, 21:21
Да все просто:
Код
C++ (Qt)
QStringList
lst
=
str.
split
(
QRegExp
(
"
\\
s{2,}"
)
)
;
qDebug
(
)
<<
lst
;
Вывод:
("8203", "Цикло-Прогинова драже х 21", "Schering GmbH und Co. Produktions KG", "6", "490,97р.", "490,97р.", "( ВCE ГРУППЫ )")
Спасибо, гараздо так проще, но беда как говориться не приходит одна, в файлике также содержаться строки такого содержания:
680000527 Хумулин НПХ картрид.100МЕ/мл 3 мл х 5 Eli Lilly 3 1440,76р. 1440,76р. ( ВCE ГРУППЫ )
и там к сожалению после кода всего один пробел, и выражение уже не срабатывает, буду думать что с этим можно сделать!
«
Последнее редактирование: Октябрь 18, 2009, 16:01 от kadr
»
Записан
lit-uriy
Джедай : наставник для всех
Offline
Сообщений: 3880
Re: Работа с файлами
«
Ответ #13 :
Октябрь 18, 2009, 16:45 »
>>буду думать что с этим можно сделать!
Я тебе написал вариант и он соответствует последнему примеру.
Записан
Юра.
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: Работа с файлами
«
Ответ #14 :
Октябрь 19, 2009, 09:39 »
Цитата: kadr от Октябрь 18, 2009, 15:59
и там к сожалению после кода всего один пробел, и выражение уже не срабатывает, буду думать что с этим можно сделать!
Никто не сможет придумать 100% корректное решение для некорректных/неопределенных данных (как в данном случае). Разбирайте как предложено выше и ловите ошибки (например, или поле не переводится в число или получается слишком много полей и.т.п.). Ошибочную строку исправляете в текстовом редакторе и повторяете процедуру. Не очень креативно но задачу решает
Записан
Страниц: [
1
]
2
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...