кодовая страница в классе QTableView

 
+1
 
C++
ava
olegkuzn | 25.01.2013, 12:37
Здраствуйте.
Помогите решить проблему.
Вот простенькая програмка :

#include <QtGui/QApplication>

#include <QtSql/QSqlDatabase>
#include <QtSql/QSqlError>
#include <QtSql/QSqlQuery>
#include <QDebug>
#include <QTextCodec>
#include <QMessageBox>
#include <QTableView>
#include <QSqlQueryModel>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    // установка кодовой страницы
    QTextCodec::setCodecForCStrings(QTextCodec::codecForName("CP1251"));

    // открытие базы данных
    QSqlDatabase db = QSqlDatabase::addDatabase( "QODBC");
    db.setDatabaseName( "DBase");
    if( !db.open())
    {
        QMessageBox::critical(0,"Ошибка","Не могу открыть базу данных");
        exit(1);
    }

    // создание модели базы банных
    QSqlQueryModel* model = new QSqlQueryModel();
    model->setQuery("select tabnmb, fio, sex, borndate, disdatepr from persons");


    // создание вида базы данных и привязка его к модели
    QTableView *view = new QTableView;
    view->setModel( model);
    view->setWindowTitle("База сотрудников");
    view->setGeometry(100, 100, 800, 400);

    view->show();

    return a.exec();
}


База данных - persons.dbf. Файл выгружен в кодовой странице cp-1251.
DBase - ODBC драйвер для  DBASE IV.
В объекте view вместо руских символов появляется грязь,
хотя установлена кодовая страница : "QTextCodec::setCodecForCStrings(QTextCodec::codecForName("CP1251"));"
Подскажите в чем проблема. Программа запускается в Windows 7 Professional.

Заранее спасибо.


Ответы (2)
ava
borisbn | 25.01.2013, 15:28 #
замени
Цитата (olegkuzn @  25.1.2013,  11:37 findReferencedText)
 "QTextCodec::setCodecForCStrings(QTextCodec::codecForName("Windows-1251"));"
ava
olegkuzn | 29.01.2013, 12:22 #
Пробился только тогда когда поменял кодовую страницу dbf-файла c cp-1251 на cp866.
После чего не понадобилась даже строка :

// установка кодовой страницы
    QTextCodec::setCodecForCStrings(QTextCodec::codecForName("CP1251"));


Непонятно почему так получилось.
Может быть это какие-то неучтенные настойки  в ODBC - драйвере  или просто глюк.

Зарегистрируйтесь или войдите, чтобы написать.
Фирма дня
Вы также можете добавить свою фирму в каталог IT-фирм, и публиковать статьи, новости, вакансии и другую информацию от имени фирмы.
Подробнее
Участники
advanced
Отправить