ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

c-从html文件读取Unicode内容时,为什么QTextBrowser中的Unicode字体无法正确显示?

2019-10-13 15:05:11  阅读:253  来源: 互联网

标签:c unicode qt qtextbrowser


我正在读取html文件.该文件基本上包含Unicode文本,如下所示:

<b>akko- sati (ā + kruś), akkhāti (ā + khyā), abbahati (ā + bṛh)</b>

但是QTextBrowser不能解释Unicode字体.因此,QTextBrowser将它们显示如下:

akko- sati (Ä + kruÅ›), akkhÄti (Ä + khyÄ), abbahati (Ä + bá¹›h)

QTextBrowser正确解释了html标签.但是Unicode字体怎么了?

以下是我用于读取和填充Unicode内容的代码:

void MainWindow::populateTextBrowser(const QModelIndex &index)
{
    QFile file("Data\\" + index.data().toString() + ".html");
    if (!file.open(QFile::ReadOnly | QFile::Text)) {
         statusBar()->showMessage("Cannot open file: " + file.fileName());
    }
    QTextStream textStream1(&file);

    QString string = "<meta http-equiv='Content-Type' content='text/html; charset=utf-8' /><link rel='stylesheet' type='text/css' href='Data/Accessories/qss.css' />";
    string += textStream1.readAll();

    ui->textBrowser->setHtml(string); 
} 

但是,如果我不从html文件中读取Unicode内容,而是直接将它们键入参数中,则只有它可以解释Unicode字体.例如,如果我按如下操作就可以了:

ui->textBrowser->setHtml("<b>akko- sati (ā + kruś), akkhāti (ā + khyā), abbahati (ā + bṛh)</b>");

如何从html文件中读取Unicode内容并将其显示在QTextBrowser中?

如果有人向我展示代码中的错误部分或告诉我解决问题的更好方法,我将非常感激.

解决方法:

您将一个二进制文件读入QString,但不告诉程序哪个字节对应于哪个unicode字符,即,您也没有指定“ encoding”. “编解码器”.

要调试您的问题,请询问QTextStream默认使用哪些代码:

QTextStream textStream1(&file);
qDebug() << textStream1.codec()->name();

在我的Linux系统上,该名称已经是“ UTF-8”,但在您的系统上可能有所不同.要强制QTextStream将输入解释为UTF-8,请使用QTextStream::setCodec.

标签:c,unicode,qt,qtextbrowser
来源: https://codeday.me/bug/20191013/1908771.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有