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

郑州最新发布seo全称英文怎么说

郑州最新发布,seo全称英文怎么说,做旅游的网站 是什么风格,山东省建设科技协会网站首页1.简介 一直以来,都想学习一下C/C如何操作excel表,在网上调研了一下,觉得使用C/C去操作很麻烦,遂转向QT这边;QT有一个自带的类QAxObject,可以使用他去操作,但随着了解的深入,觉得他…

1.简介

一直以来,都想学习一下C/C++如何操作excel表,在网上调研了一下,觉得使用C/C++去操作很麻烦,遂转向QT这边;QT有一个自带的类QAxObject,可以使用他去操作,但随着了解的深入,觉得他并不是很好,有很多其他缺陷(例如必须电脑安装了办公软件才可以进行操作等),所以继续调研,终于找到了QT的一个第三方库可以很好的实现:QtXlsx. 
 

Github下载:https://github.com/dbzhang800/QtXlsxWriter
官方文档:http://qtxlsx.debao.me/

在Github下载后,可以直接添加到QtCreator项目中,也可以编译成lib库后再添加到VS中去使用。

2、下载QtXlsx

点击链接进入Github下载

 下载解压后得到如下文件

二、QtXlsx源码嵌入QTCreator中使用

新建一个QTCreator窗体项目

将上图src文件夹拷贝到该项目路径中

之后双击项目中的.pro文件

将如下代码拷贝到.pro文件中

include(src/xlsx/qtxlsx.pri)

Ctrl + s 保存一下,就可以把QtXlsx源码模块加载进来啦!

可以在项目构造函数中添加如下代码进行测试:

#include "xlsxdocument.h"
#include "xlsxchartsheet.h"
#include "xlsxcellrange.h"
#include "xlsxchart.h"
#include "xlsxrichstring.h"
#include "xlsxworkbook.h"QXlsx::Document xlsx;
xlsx.write(1, 2, "Hello Qt!");
xlsx.write(2, 2, QString::fromLocal8Bit("中文"));
xlsx.saveAs("Text.xlsx");

编译运行后,就可以在项目路径看到程序创建的Text.xlsx文件,打开后就可以看到写入的 "Hello Qt!"和"中文".

三、QtXlsx源码编译成为.lib库使用

1. 下载安装Perl

下载安装:Perl

下载链接:Strawberry Perl for Windows

注意,这个是一定要下载安装的,否则编译lib库会编译失败!!! 

下载后默认安装即可

2. 编译QtXlsx

打开下载的QtXlsx文件夹,双击打开.pro

 根据自己安装的vs版本,选择相应的msvc编译

 打开后直接点击编译

编译完成后,就可以在相应路径找到编译好的lib库

3. 在vs中使用

新建vsQT项目,将include文件夹和Qt5Xlsxd.dll和Qt5Xlsxd.lib拷贝到项目路径中;

将QtXlsxWriter-master文件夹整个拷贝到项目路径中;

拷贝之后项目路径文件,下图方框中的就是我们需要拷贝的文件

右键项目 - 属性 - C/C++ - 常规 - 附加包含目录,把头文件路径添加进来

右键项目 - 属性 - 链接器 - 输入 - 附加依赖项,添加Qt5Xlsxd.lib

之后,可以加入头文件

#include "xlsxdocument.h"
#include "xlsxchartsheet.h"
#include "xlsxcellrange.h"
#include "xlsxchart.h"
#include "xlsxrichstring.h"
#include "xlsxworkbook.h"

在构造函数中加入代码

	QXlsx::Document xlsx;xlsx.write(1, 2, "Hello Qt!");xlsx.write(2, 2, QString::fromLocal8Bit("中文"));xlsx.saveAs("Text.xlsx");

编译运行,不出意外的话, 在项目路径会一个名为Text.xlsx的文件,双击打开

 数据也已经写入,测试成功! 

四、QtXlsx
1. 知识点

a. 定义

QXlsx::Document xlsx;QXlsx::Document xlsx("Text.xlsx");

b. 往单元格中写入数据

writexlsx.write(2, 2, "中文");         参数一是行,参数二是列,参数三是数据xlsx.write("C3", "C3");        参数一是对应单元格名字,参数二是数据

c. 设置行高

setRowHeightxlsx.setRowHeight(4, 30);        设置第四行高度为30

d. 设置列宽

setColumnWidthxlsx.setColumnWidth(3, 50);         设置第三列宽度为50

 e. 设置单元格样式

QXlsx::Format format;format.setFontColor(Qt::red);                  // 设置字体颜色为红色format.setFontBold(true);                         // 设置加粗format.setFontSize(30);                            // 设置字体大小format.setFontItalic(true);                          // 设置倾斜format.setFontName("楷体");                     // 设置字体format.setPatternBackgroundColor(QColor(100, 200, 100));         // 设置单元格背景颜色format.setHorizontalAlignment(QXlsx::Format::AlignHCenter);      // 设置水平居中,更多参考enum HorizontalAlignment枚举format.setVerticalAlignment(QXlsx::Format::AlignVCenter);           // 设置垂直居中format.setBorderColor(QColor(50, 50, 50));                                    // 设置边框颜色format.setFontUnderline(QXlsx::Format::FontUnderlineDouble);    // 设置双下划线,更多参考enum FontUnderline枚举format.setFontUnderline(QXlsx::Format::FontUnderlineSingle);      // 设置单下划线format.setFillPattern(QXlsx::Format::PatternLightUp);                     // 填充方式,更多参考enum FillPattern枚举xlsx.write("C4", "红色|加粗|30", format);        作为第三个参数

f. 设置单元格方框

setBorderStyleformat.setBorderStyle(QXlsx::Format::BorderThin);        更多参考enum BorderStyle枚举

g. 合并单元格

mergeCellsxlsx.mergeCells("C4:E6");        参数指定那个单元格区间

h. 取消合并

unmergeCellsxlsx.unmergeCells("C4:E6");        参数指定的单元格区间一定是要已经合并的,否则打开xlsx文件报错

i. 读取单元格中的数据

readQString str1 = xlsx.read(1, 1).toString();        指定行列获取QString str2 = xlsx.read("B2").toString();        指定单元格名字获取

j. 获得单元格对象

cellAtQXlsx::Cell *cell = xlsx.cellAt("C4");                获取到的是指针对象QXlsx::Cell *cell = xlsx.cellAt(1, 1);cell->value();        可以通过value()函数获取单元格中的值

k. 添加工作表

addSheetxlsx.addSheet("sheet_2");        添加这一张名为“sheet_2”的工作表

l. 工作表重命名

renameSheetxlsx.workbook()->renameSheet(1, "sheet_3");        将索引为1(也就是第二张)的工作表命名为“sheet_3”

m. 选择当前工作表

selectSheetxlsx.selectSheet("sheet_3");        选择名为“sheet_3”的工作表为当前xlsx工作表

n. 获得所有工作表的名字

sheetNames
QStringList sheetList = xlsx.sheetNames();        获取返回的是一个字符串链表

o. 获取工作簿对象

workbookQXlsx::Workbook *workBook = xlsx.workbook();

p. 获取当前工作簿的第一张sheet工作表

QXlsx::Worksheet *workSheet = static_cast<QXlsx::Worksheet*>(workBook->sheet(0));

q. 获取当前sheet表所使用到的行数

int row = workSheet->dimension().rowCount();

r. 获取当前sheet表所使用到的列数

int colum = workSheet->dimension().columnCount();

s. 遍历sheet表中有数据的单元格

for (int i = 0; i < row; i++) {                                                               for (int j = 0; j < colum; j++) {                                                         // 获取单元格                                                                              QXlsx::Cell *cell = workSheet->cellAt(i, j);    // 读取单元格                              if (cell) {                                                                           qDebug() << "(" << i << ", " << j << ")\t" << cell->value().toString().trimmed();    // trimmed 去除字符串两侧的空格                                                                                              }                                                                                     }                                                                                         
}                                                                                             

t. 删除单元格数据

xlsx.write("G5", "");        直接重新设置为空即可

u. 修改单元格数据

xlsx.write("G6", "修改");        重新对单元格写入数据即可

v. 保存

saveAsxlsx.saveAs("Text.xlsx");        初始化xlsx对象时没有指定excel文件,那么保存时使用这个savexlsx.save();        初始化xlsx对象时,指定了excel文件,那么保存时使用这个

w. 设置单元格中字符串不同字体颜色

RichString

QXlsx::Document xlsx("Text.xlsx");             QXlsx::Format blue;     // 设置字体颜色              
blue.setFontColor(Qt::blue);                   
QXlsx::Format red;                             
red.setFontColor(Qt::red);                     
red.setFontSize(20);    // 设置字体大小              
QXlsx::Format bold;                            
bold.setFontBold(true); // 设置字体加粗              QXlsx::RichString rich;                        
rich.addFragment("test", blue);                
rich.addFragment("QT", red);                   
rich.addFragment("中文", bold);                  xlsx.write("C3", rich);                        xlsx.save();                                   

x. 给单元格命名

xlsx.defineName("Cell_1", "=Sheet1!$A$1:$A$10");    // A1-A10命名为Cell_1
xlsx.defineName("Cell_2", "=Sheet1!$B$1:$B$10", "这是描述信息");  // B1-B10命名为Cell_2

y. 赋值

xlsx.defineName("Factor", "=0.5");         // 将0.5赋值给Factor,相当于变量赋值一样,我们就可以使用这个变量了

z. 使用公式

xlsx.write(11, 1, "=SUM(Cell_1)");  // 计算A1-A10数据总和,并写入(11,1)单元格中
xlsx.write(15, 1, "=SUM($A$1:$A$10)");  // 计算A1-A10数据总和,并写入(15,1)单元格中


使用公式和变量

xlsx.write(12, 1, "=SUM(Cell_1)*Factor");   // 计算A1-A10数据总和再乘以0.5,并写入(12,1)单元格中
xlsx.write(16, 1, "=SUM($A$1:$A$10)*Factor"); // 计算A1-A10数据总和再乘以0.5,并写入(16,1)单元格中
xlsx.write(13, 2, "=SUM($B$1:B$10)*0.1");    // B1 - B10 计算总和后乘以0.1

五、QtXlsx知识点补充

1.QStringList sheetNames() const


2.bool addSheet(const QString &name = QString(), AbstractSheet::SheetType type = AbstractSheet::ST_WorkSheet)


3.bool insertSheet(int index, const QString &name = QString(), AbstractSheet::SheetType type = AbstractSheet::ST_WorkSheet)

4.bool renameSheet(const QString &oldName, const QString &newName)

5.bool moveSheet(const QString &srcName, int distIndex)

6.bool deleteSheet(const QString &name)


7.AbstractSheet *Document::sheet(const QString &sheetName) const

8.AbstractSheet::SheetState AbstractSheet::sheetState() const

9.void AbstractSheet::setSheetState(SheetState state)

10.bool AbstractSheet::isHidden() const

11.bool AbstractSheet::isVisible() const

12.void AbstractSheet::setHidden(bool hidden)

13.void AbstractSheet::setVisible(bool visible)\

14.Chart *Document::insertChart(int row, int col, const QSize &size)

15.void Chart::setChartType(ChartType type)

16.void Chart::addSeries(const CellRange &range, AbstractSheet *sheet, bool headerH, bool headerV, bool swapHeaders)

17.void Chart::setChartLegend(Chart::ChartAxisPos legendPos, bool overlay)

18.void Chart::setChartTitle(QString strchartTitle)

19.void Chart::setGridlinesEnable(bool majorGridlinesEnable, bool minorGridlinesEnable)
 

20.int Document::insertImage(int row, int column, const QImage &image)

21.uint Document::getImageCount()

22.bool Document::getImage(int imageIndex, QImage& img)

23.bool Document::getImage(int row, int col, QImage &img)

不错的连接:https://blog.csdn.net/qq_43627907/category_11756312.html​​​​​​​


文章转载自:
http://boree.hwbf.cn
http://hierarchize.hwbf.cn
http://dashi.hwbf.cn
http://supermanly.hwbf.cn
http://positron.hwbf.cn
http://nairobi.hwbf.cn
http://limina.hwbf.cn
http://livelily.hwbf.cn
http://kornberg.hwbf.cn
http://millennial.hwbf.cn
http://atilt.hwbf.cn
http://indeterminable.hwbf.cn
http://bindwood.hwbf.cn
http://chicklet.hwbf.cn
http://recalescence.hwbf.cn
http://adze.hwbf.cn
http://reniform.hwbf.cn
http://outfield.hwbf.cn
http://idly.hwbf.cn
http://octavo.hwbf.cn
http://myelocytic.hwbf.cn
http://oxfordshire.hwbf.cn
http://desperateness.hwbf.cn
http://hendiadys.hwbf.cn
http://sectarial.hwbf.cn
http://yellowy.hwbf.cn
http://rotation.hwbf.cn
http://khotan.hwbf.cn
http://ineffectual.hwbf.cn
http://minuscule.hwbf.cn
http://hypocycloid.hwbf.cn
http://erythrosin.hwbf.cn
http://advowson.hwbf.cn
http://methodological.hwbf.cn
http://biker.hwbf.cn
http://sac.hwbf.cn
http://manage.hwbf.cn
http://beatification.hwbf.cn
http://uncalculating.hwbf.cn
http://constituent.hwbf.cn
http://awedly.hwbf.cn
http://amphidromia.hwbf.cn
http://spheroidic.hwbf.cn
http://diamondback.hwbf.cn
http://horsing.hwbf.cn
http://delphine.hwbf.cn
http://vasodilator.hwbf.cn
http://vibrioid.hwbf.cn
http://boundless.hwbf.cn
http://tholepin.hwbf.cn
http://pandemonium.hwbf.cn
http://perborate.hwbf.cn
http://crumply.hwbf.cn
http://catalogue.hwbf.cn
http://dissipative.hwbf.cn
http://onside.hwbf.cn
http://sexangular.hwbf.cn
http://plowboy.hwbf.cn
http://acidaemia.hwbf.cn
http://alutaceous.hwbf.cn
http://forgettery.hwbf.cn
http://cosmical.hwbf.cn
http://oem.hwbf.cn
http://agenesis.hwbf.cn
http://cullender.hwbf.cn
http://mercaptoethanol.hwbf.cn
http://paupiette.hwbf.cn
http://druggist.hwbf.cn
http://rhetoric.hwbf.cn
http://memorial.hwbf.cn
http://crepuscular.hwbf.cn
http://checktaker.hwbf.cn
http://inviting.hwbf.cn
http://pectoral.hwbf.cn
http://contrariously.hwbf.cn
http://manfully.hwbf.cn
http://repentant.hwbf.cn
http://externalise.hwbf.cn
http://neuron.hwbf.cn
http://flageolet.hwbf.cn
http://zymogen.hwbf.cn
http://gudrun.hwbf.cn
http://electrolyse.hwbf.cn
http://dory.hwbf.cn
http://hans.hwbf.cn
http://dustcoat.hwbf.cn
http://zairean.hwbf.cn
http://iupac.hwbf.cn
http://zoroastrian.hwbf.cn
http://mesopeak.hwbf.cn
http://place.hwbf.cn
http://kampong.hwbf.cn
http://achech.hwbf.cn
http://homoousion.hwbf.cn
http://debbie.hwbf.cn
http://postmarital.hwbf.cn
http://rind.hwbf.cn
http://skylight.hwbf.cn
http://dubious.hwbf.cn
http://exploit.hwbf.cn
http://www.15wanjia.com/news/82836.html

相关文章:

  • 上海做家教网站有哪些国际新闻军事最新消息
  • 域名论坛网站游戏优化大师官方下载
  • 国家住房部和城乡建设部 网站首页电商平台推广公司
  • 辽宁省住房和城乡建设厅网站网络优化工程师是做什么的
  • 微信公众号开发需要什么技术南京seo按天计费
  • 好点的开发网站的公司写软文
  • 济南著名网站建设网络推广怎么收费
  • 免费网站导航建设南宁百度关键词推广
  • 营销型网站的名词解释千锋教育培训多少钱
  • 大连网站排名优化公司交友平台
  • 三河网站建设公司信息流广告代理商排名
  • 黑龙江网站建站建设国内打开google网页的方法
  • 网站百度收录快最新国际消息
  • 中企做的网站seo优化需要多少钱
  • 做网站的需要什么软件营销策略怎么写模板
  • wordpress多人聊天室优化大师电脑版官网
  • 自己的网站怎么做排名姓名查询
  • php怎么建立网站国际大新闻最新消息
  • 一般做网站带宽选择多大的万维网域名注册查询
  • 美食网站开发与设计任务书友链网站
  • 织梦做的网站打开慢全国疫情排行榜
  • python web网站开发百度快照官网登录
  • 论坛网站开发费用网站定制的公司
  • 网站怎么做切换中英文新闻最新消息
  • dedecms做网站怎么查看关键词搜索网站
  • psd做模板下载网站北京seo关键词排名优化
  • 没网站能不能cpc广告点击赚钱做seo平台有哪些
  • 南充网站建设工作室谷歌关键词搜索量数据查询
  • 装修公司网站wordpress 模板百度竞价广告怎么收费
  • 建设网站要先给钱才能做云盘搜