当前位置: 首页 > news >正文

天津企业网站设计报价百度推广登陆后台

天津企业网站设计报价,百度推广登陆后台,app定制网站开发,包装设计需要学什么软件原版xlslib输出UTF8汉字有误,我在网上找到这个古老的帖子修改开源xlslib使得支持输出UTF8中文Excel文件内容不乱码, 它自定义了2个指定UTF8编码的重载label()函数。 照做后,第一步发现编译有错 In file included from ./xlslib.h:53,from xlslib/cbridg…

原版xlslib输出UTF8汉字有误,我在网上找到这个古老的帖子修改开源xlslib使得支持输出UTF8中文Excel文件内容不乱码, 它自定义了2个指定UTF8编码的重载label()函数。
照做后,第一步发现编译有错

In file included from ./xlslib.h:53,from xlslib/cbridge.cpp:50:
./xlslib/sheetrec.h:339:72: error: 'ustring' in namespace 'std' does not name a type; did you mean 'wstring'?339 | cell_t* label(int code, unsigned16_t row, unsigned16_t col, const std::ustring& strlabel, xf_t* pxformat = NULL);|                                                                        ^~~~~~~|                                                                        wstring

观察同一个函数的其他重载声明,ustring命名空间不是std而是xlslib_strings,照着改成如下声明后,make通过。在xlslib/xlslib/src/.libs中生成了新的动态链接库文件。

		cell_t* label(unsigned32_t row, unsigned32_t col,const xlslib_strings::ustring& strlabel, xf_t* pxformat = NULL);
/*
* 在xlslib/src/sheetrec.h中增加如下代码
*/
cell_t* label(int code, unsigned16_t row, unsigned16_t col, const xlslib_strings::ustring& strlabel, xf_t* pxformat = NULL);

直接用ws->label(UTF8,0, col, "Col_中文");输出的仍是乱码。需要在字符串前加L修饰符,指定它是宽字符串才能输出汉字,但L"Col_汉字" + std::to_string(col)编译又会报错。

在https://www.runoob.com/cplusplus/cpp-libs-codecvt.html 教程网站上找到了std::wstring_convert转换器,写成如下就能正确输出UTF8汉字和数字混合字符串了。

        // 写入标题enum { UTF8, GBK };for (int col = 0; col < cols; ++col) {//ws->label(UTF8,0, col, L"Col_中文");std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> converter;// 原始的 UTF-8 字符串//std::string narrow_string = "Hello, World!";// 转换为 UTF-16 宽字符串//std::wstring wide_string = converter.from_bytes(narrow_string);std::wstring wide_string = converter.from_bytes(("Col_汉字" + std::to_string(col)).c_str());ws->label(UTF8,0, col, wide_string);}

为防止原帖不可访问。将它的改写代码抄录如下,命名空间已修改

/*
* 在xlslib/src/sheetrec.h中增加如下代码
*/
cell_t* label(int code, unsigned16_t row, unsigned16_t col, const xlslib_strings::ustring& strlabel, xf_t* pxformat = NULL);
cell_t* label(int code, unsigned16_t row, unsigned16_t col, const char* strlabel, xf_t* pxformat = NULL);/*
* 在xlslib/src/sheetrec.cpp中增加如下代码
*/
cell_t* worksheet::label(int code, unsigned16_t row, unsigned16_t col,const ustring& strlabel, xf_t* pxformat)
{enum { UTF8, GBK };u16string str16;label_t* lbl;u16string::const_iterator u16begin, u16end;ustring::const_iterator ubegin, uend;size_t len;if (code == UTF8) {len = strlabel.length();str16.reserve(len);ubegin = strlabel.begin();uend = strlabel.end();while(ubegin != uend) {unichar_t c;c = *ubegin++;str16.push_back(c);       }lbl = new label_t(m_GlobalRecords, row, col, str16, pxformat);AddCell((cell_t*)lbl);return (cell_t*)lbl;} else {return NULL;}
}
cell_t* worksheet::label(int code, unsigned16_t row, unsigned16_t col,const char* strlabel, xf_t* pxformat)
{enum { UTF8, GBK };unsigned16_t u16;u16string str16;label_t* lbl;wstring::const_iterator wbegin, wend;size_t len;if (code == UTF8) {if (strlabel == NULL) {return NULL;} else {len = strlen(strlabel);wchar_t wcs[len+1];mbstowcs(wcs, strlabel, len+1);len = wcslen(wcs);for (int i = 0; i < len; i++) {u16 = wcs[i];str16.push_back(u16);}}lbl = new label_t(m_GlobalRecords, row, col, str16, pxformat);AddCell((cell_t*)lbl);return (cell_t*)lbl;} else {return NULL;}
}
http://www.khdw.cn/news/28975.html

相关文章:

  • 网站如何做的有气质百度网址导航主页
  • 新网站怎么做网络推广合肥推广外包公司
  • 网站开发技术背景介绍网络营销与推广
  • 怎么做繁体字网站直通车关键词优化口诀
  • b2c电商网站有哪些优势如何在百度发广告推广
  • 怎么把自己的网站推广出去网络营销软件推广
  • 黄岛网站建设多少钱如何优化关键词
  • 五一自学网免费教程官网湖南seo优化报价
  • 网站制作高端网站建设百度推广的广告靠谱吗
  • wordpress 插件 支付seo外贸网站制作
  • 手机设置管理网站企业管理系统
  • 成都pc网站建设武汉谷歌seo
  • 做网站时需要注意什么问题怎么制作微信小程序
  • 织梦做的网站图片显示不了合肥网络推广服务
  • 动态网站影响收录吗深圳互联网营销
  • 云霄城乡建设局网站南宁网站制作
  • 重庆妇科医院咨询淘宝seo搜索引擎原理
  • 浙江龙游疫情最新消息福州短视频seo平台
  • 如何建设网站兴田德润可以吗推广公司简介
  • 企业加盟网站建设武汉seo价格
  • 上海个体户注册代办seo系统培训班
  • 可以做样机图的网站友情链接翻译
  • 如何申请域名邮箱长沙企业seo优化
  • 如何把物流做免费网站网络营销的优势包括
  • 网站建设导向友情链接购买平台
  • 那些开店的网站是自己做的吗网站域名注册
  • 潍坊建设网站公司电话怎么给公司做网站推广
  • 公众号引流推广西安seo整站优化
  • 网站给部分文字做遮挡代码广州seo优化费用
  • wordpress 电话长春seo代理