Реклама
  • 22 ноября 2016 г. 15:51

Запись в файл на андроиде

Qt

Добрый день. Вопрос.

Чтение из файла на андроид устройстве организовать можно.
Но как в тот же файл что-то записать. хыть строчку какую-нить.

При таком варианте

QFile file_compressed(":/db/intest.txt");
    if (!file_compressed.open(QIODevice::WriteOnly)){
       QString line = "asd";
       QByteArray ba;
       ba.append(line);       
       file_compressed.write(ba);
    }
    file_compressed.close();

он просто говорит QIODevice::write (QFile, “:/db/intest.txt”): device not open

При рытье в сети нашел только один внятный ответ и тот не обнадеживает. Что мол QIODevice на андроиде работает только на чтение.

Есть варианты как обойти данный момент?

  • #
  • 22 ноября 2016 г. 16:33
Что-то я не помню такой проблемы.
К тому же Qt базу данных SQLite без проблем пишет. А там должен использоваться также QIODevice.
Проблема скорее всего в том, что пытаетесь через qrc ресурсы писать. Я имею ввиду вот это “:/db/intest.txt”.
Вполне возможно, что здесь могут быть грабли какие-нибудь. А если писать в определённое место в памяти телефона, используя QStandardPaths, то такой проблемы не должно быть.

НЕ не база данных а прос в файл. ПРосто на андроид устройстве при каком то действии что-то текстовое пишем в файл. НЕ в БД.

Но вопрос решен.

вот так

QString fileName  = "intest.txt";
QString filePath = QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation);
filePath.append( "/"+fileName);
 
QFile file_compressed(filePath);

и тогда запись начинает работать

Реклама
  • andrey
  • #
  • Ответ был помечен как решение
  • 22 ноября 2016 г. 16:56

База данных SQLite, текстовый файл – это всё одно и тоже. В обоих случаях это файл, который можно открыть в текстовом редакторе. Просто у SQLite есть собственная структура. Я вот это имел ввиду. А если пишется SQLite БД, то и обычный текстовый файл будет записываться.

Ну и да. Как я и сказал, через QStandardPaths указать место файла на телефоне и вперёд записывать.

Реклама

Ответы

Только авторизованные пользователи могут отвечать на форуме.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
Последние комментарии
  • EVILEG
  • 24 апреля 2017 г. 20:44
Подключение вашего Qt приложения к сервисам Google, используя OAuth 2.0

У меня пока мыслей на этот счёт нет ((

Подключение вашего Qt приложения к сервисам Google, используя OAuth 2.0

Пробовал играться с шарком, либо я криво смотрел, либо почему-то POST запросы на oauth.yandex.ru не летят, хотя должны постом лететь, я и исходники QOAuth2AuthorizationCodeFlow ковырял на пред

  • EVILEG
  • 24 апреля 2017 г. 13:39
Подключение вашего Qt приложения к сервисам Google, используя OAuth 2.0

Возможно, стоит Wireshark`ом запросы посмотреть. В чём отличие идёт аякс запроса от запроса из библиотеки. Возможно, что не хватает какой-нибудь заголовочной информации.

Сейчас обсуждают на форуме
Signal из Dialog

Добрый вечер.Вроде бы разобрался как работают signal и slot, но возник такой вопрос.Есть Widget из которого открывается Dialog, в Dialog-е есть кнопка, savebutton, по которой происходит вс...

  • EVILEG
  • 26 апреля 2017 г. 20:53
Область

Да. Это возможно. Определитесь только с задачей, которую эта область должна выполнять. А то получается, что нужно создать что-то, в чём нужно делать что-то. Какой-то абстрактный конь в вакууме...

  • Arrow
  • 26 апреля 2017 г. 20:10
Дополнительное окошко

Если кто-то собрался такое разрабатывать, то думаю лучше идти к тем, кто за это хорошо заплатит. Самому писать в одиночку в надежде продать не вариант. :)

  • EVILEG
  • 26 апреля 2017 г. 19:20
Сохранение PDF файла в БД

Да. Это весьма удобно, что к базе данных может обращаться.

  • EVILEG
  • 26 апреля 2017 г. 19:11
Qt Installer Framework и Redistributable пакеты.

Смотрю, всё обошлось даже весьма малой кровью. Замечательно.