Privacy policyContactsAbout siteOpinionsGitHubDonate
© EVILEG 2015-2018
Recommend hosting
TIMEWEB
m
March 29, 2019, 8:01 p.m.

Открытие и считыванание файла в автоматическом режиме

Qt

Форумчане, столкнулся с проблемой открытия файла без участия пользователя. Принимаю файл с устройства по протоколу Tcp/Ip, ставится задача перевести принимаемый файл в автоматическом режиме в формат .csv(Excel). Проблема заключается в следующем, работа функции начинается после получения сигнала о получении файла, соответственно в теле функции произвожу проверку на существование самого файла в директории if(QFile::exists(asd)), проверка производится успешно, условие открытия файла так же всегда выполняется if(myFile.open(QIODevice::ReadWrite)), но в QByteArray не проивзодится запись, он пустой, соответственно и весь последующий алгоритм не работает. При этом, если я прохожу все этапы под отладчиком, с установкой точек останова, то ArrayB заполняется так как надо, т.е. он не пустой. Связываю данную проблему с тем, что выполнение функции просходит именно в момент создания файла, т.е. моё устройство успело только создать файл, а записать в него данные не успело, и происходит в этот момент запуск моей функции MainWindow::AutoExportCSVfile() .

void MainWindow::AutoExportCSVfile()
{ 
    QStringList listExcelExport;
    QString asd1;
    QByteArray arrayB;
    QString asd = LastDirectory +"/" + NewMeasurmentDLG.getFileName() ;    //LastDirectory = D:/Data , NewMeasurmentDLG.getFileName() = myNewFile.dat
    asd1 = asd;
    asd1.chop(3);
    asd1+="csv";
    qDebug()<<"File exists?"<<QFile::exists(asd);      //Debug = true , Run = true
    if(QFile::exists(asd))
    {
        QFile myFile(asd);
        qDebug()<<myFile.bytesAvailable();          //Debug = нужное количество байт , Run = 0
        if(myFile.open(QIODevice::ReadWrite))
        {
            qDebug()<<"File can read?"<<myFile.waitForReadyRead(3000);    //Debug = false , Run = false
            qDebug()<<"Open File? "<<myFile.isOpen();                     //Debug = true , Run = true
            arrayB=myFile.readAll();
            qDebug()<<"lenght arrayB?"<<arrayB.length();                  //Debug = нужная длинна , Run = 0
            myFile.close();
            listExcelExport= arrayB.split(QRegExp("[\r \n ;]+"), QString::SkipEmptyParts);
            QFile exportFile(asd1);
            if(exportFile.open(QIODevice::WriteOnly))                    //Debug = true , Run = true
            {
                QTextStream ts(&exportFile);

                qDebug()<<"Dlinna listExcelExport = "<<listExcelExport.length();               
                for(int c= 80; c<listExcelExport.length()-1;c+=2)
                {
                    strList<<listExcelExport[c] + ";" + listExcelExport[c+1] +";";
                }
                ts<<strList.join("\n");
                exportFile.close();
            }
            QString outS= "Файл " + asd1 + " успешно сохранён!";
            textStatusBar->setText(outS);                     //Вывод в строку состояния сообщения 

        }
    }
}

Пытался решить дануую проблему путём бесконечного цикла ожидания waitForReadyRead(-1), но цикл никогда не завершается, всегда условие false (При этом файл уже полностью получен)

for (;;)
    {
        if(myFile.waitForReadyRead(-1))
        {
            break;
        }
    }

Может кто сталкивался с подобным? Файл всегда имеет разную длинну, условие проверки по количеству байт тоже не сработает.

Virtual hosting with 10 percent discount
Virtual hosting with 10 percent discount
EVILEG offers reliable hosting with a 10% discount for virtual hosting and 5% for VPS
1

Добрый день.

Думаю, что проблема не в том куске кода, который вы привели, а в том, который вызывает экспорт файла в csv формат. Если вы принимаете данные по TCP/IP, то, если я понимаю правильно, вы пытаетесь делать экспорт файла ещё до того, как изначальный файл вообще был принят. Думаю, что это не правильно. Вам нужно либо дождаться полной записи исходного файла, а потом уже выполнить его экспорт. Либо делать корректировку файла на лету без создания исходного файла.

  • В первом случае нужно выполнять вызов метода AutoExportCSVfile() только после окончания передачи данных.
  • Во втором случае нужно модифицировать методы принимающие данные, листинга которых здесь нет.

Я бы вам предложил сначала реализовать первый вариант.

0

Comments

Only authorized users can post comments.
Please, Log in or Sign up
AA
April 17, 2019, 7:40 p.m.
Anton Ablin

Qt - Test 001. Signals and slots

  • Result:73points,
  • Rating points1
E
April 17, 2019, 6:16 p.m.
Evgeny

Qt - Test 001. Signals and slots

  • Result:100points,
  • Rating points10
E
April 17, 2019, 6:14 p.m.
Evgeny

Qt - Test 001. Signals and slots

  • Result:78points,
  • Rating points2
Last comments
U
April 18, 2019, 3:37 p.m.
Unreal_man

А как иконку в хедер задать?
u
April 18, 2019, 2:15 a.m.
uaa

доброго времени,большое спасибо за пример для начинающего)при адаптации к своему проекту столкнулся с таким ньансом:в vepolyline.h в 47 строке нужна инициализация по умолчанию: int m_pointF...
E
April 11, 2019, 12:49 p.m.
Evgeny

Спасибо за ответ) У меня компоновщик на нее ругался просто. Оказалось, просто забыл Q_OBJECT в начале класса указать.
April 11, 2019, 12:29 p.m.
Евгений Легоцкой

Добрый день. Вы имели ввиду реализацию? Для сигналов в Qt реализация не пишется, это всё генерируется в moc файлах под капотом Qt.
E
April 11, 2019, 12:15 p.m.
Evgeny

Здравствуйте. А где описание функции signal1()?
Now discuss on the forum
R
April 19, 2019, 9:55 a.m.
RED_Spider

мені важко це зараз навіть перевірити, тому що знайшов коміт, це ще було в 2016 році, і цей код не буде працювати коректно зараз, єдине скажу що це були QThread
i
April 17, 2019, 3:03 p.m.
ilya.guzikov

BlinCT, на стороне ++ это делать необходимо так как в qml при использовании функции append происходит перерисовка всех точек лини(как я понимаю) и из-за этого при использовании больших массиво...
April 10, 2019, 11:20 a.m.
Алексей Внуков

может тоже кому надо будет - QML не принимает QVector<QVector<int>> , при попытке вывести полученый вектор QML показывает что это QVariant(QVector<QVector<int> ...
SN
April 10, 2019, 9:36 a.m.
Stanislav Nykytiuk

Как реализовать такое меню, что бы нажмаешь меню подменю и выбор позиции? Данные меню и подменю в базе SQL.
Join us in social networks

For registered users on the site there is a minimum amount of advertising