0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

記錄嵌入式Excel表格數(shù)據(jù)導(dǎo)出的構(gòu)建過程

嵌入式小生 ? 來源:嵌入式小生 ? 作者:iriczhao ? 2022-10-27 11:14 ? 次閱讀

最近有一個(gè)嵌入式Excel表格數(shù)據(jù)導(dǎo)出的需求:應(yīng)用軟件運(yùn)行于嵌入式Linux平臺(tái)上,在設(shè)備運(yùn)行過程中,存儲(chǔ)了許多數(shù)據(jù),這些數(shù)據(jù)想以表格的形式導(dǎo)出。

考慮到Windows平臺(tái)的普遍性,需要將數(shù)據(jù)以excel表格形式導(dǎo)出,故選擇了一個(gè)開源庫:QtXlsxWriter,本文主要記錄其編譯構(gòu)建過程。

從下列地址https://github.com/dbzhang800/QtXlsxWriter獲取安裝包,將源碼包解壓縮,目錄結(jié)構(gòu)如下圖所示:

8a47ddd8-4575-11ed-96c9-dac502259ad0.png

example目錄下存放的是示例Demo。

src目錄下存放的是xlsx的源碼。

tests目錄下存放的是測(cè)試工程。

QtXlsxWriter可以通過QtCreator來編譯構(gòu)建,所以我們打開安裝在linux平臺(tái)上的QtCreator,然后使用QtCreator打開QtXlsxWriter項(xiàng)目(選擇源碼目錄下的xxx.pro文件)。選擇對(duì)應(yīng)的編譯構(gòu)建套件后,如下圖所示:

8aaa8e6a-4575-11ed-96c9-dac502259ad0.png

點(diǎn)擊項(xiàng)目管理視圖中的頂級(jí)目錄,單擊右鍵,選擇“構(gòu)建”,即可構(gòu)建QtXlsxWriter:

8ad7df3c-4575-11ed-96c9-dac502259ad0.png

編譯成功后,將在源碼目錄的同級(jí)下創(chuàng)建構(gòu)建輸出目錄,該目錄結(jié)構(gòu)如下圖所示:

8afdbc2a-4575-11ed-96c9-dac502259ad0.png

bin :用于存放二進(jìn)制文件。(該目錄為空)

examples:示例Demo的編譯構(gòu)建輸出目錄。

include:該目錄存放關(guān)于QtXlsxWriter的頭文件:

8b33abfa-4575-11ed-96c9-dac502259ad0.png

lib:該目錄用于存放QtXlsxWriter的庫目錄:

8b5f9d78-4575-11ed-96c9-dac502259ad0.png

mkspecs:該目錄是Qt的模塊化標(biāo)識(shí)目錄,用于向Qt開發(fā)環(huán)境添加Xlsx:

8b866110-4575-11ed-96c9-dac502259ad0.png

tests:該目錄用于存放測(cè)試工程。

在上述目錄中,include、lib、mkspecs目錄是比較重要的目錄。在搭建QtXlsxWriter開發(fā)環(huán)境時(shí)需要使用到。

將構(gòu)建完成后的目錄下的bin、include、lib、mkspecs、src目錄拷貝到Qt的安裝目錄下,以在QtCreator中可以使用Qt+=xlsx加載模塊

然后可以編譯構(gòu)建一個(gè)demo示例來測(cè)試一下。本文以chart為例,其代碼如下:

#include
#include"xlsxdocument.h"
#include"xlsxcellrange.h"
#include"xlsxchart.h"

usingnamespaceQXlsx;

intmain()
{
//![0]創(chuàng)建xlsx文檔對(duì)象。向單元格總寫入數(shù)據(jù)
Documentxlsx;
for(inti=1;isetChartType(Chart::CT_Pie);
pieChart->addSeries(CellRange("A1:A9"));
pieChart->addSeries(CellRange("B1:B9"));
pieChart->addSeries(CellRange("C1:C9"));

Chart*pie3DChart=xlsx.insertChart(3,9,QSize(300,300));
pie3DChart->setChartType(Chart::CT_Pie3D);
pie3DChart->addSeries(CellRange("A1:C9"));

Chart*barChart=xlsx.insertChart(23,3,QSize(300,300));
barChart->setChartType(Chart::CT_Bar);
barChart->addSeries(CellRange("A1:C9"));

Chart*bar3DChart=xlsx.insertChart(23,9,QSize(300,300));
bar3DChart->setChartType(Chart::CT_Bar3D);
bar3DChart->addSeries(CellRange("A1:C9"));

Chart*lineChart=xlsx.insertChart(43,3,QSize(300,300));
lineChart->setChartType(Chart::CT_Line);
lineChart->addSeries(CellRange("A1:C9"));

Chart*line3DChart=xlsx.insertChart(43,9,QSize(300,300));
line3DChart->setChartType(Chart::CT_Line3D);
line3DChart->addSeries(CellRange("A1:C9"));

Chart*areaChart=xlsx.insertChart(63,3,QSize(300,300));
areaChart->setChartType(Chart::CT_Area);
areaChart->addSeries(CellRange("A1:C9"));

Chart*area3DChart=xlsx.insertChart(63,9,QSize(300,300));
area3DChart->setChartType(Chart::CT_Area3D);
area3DChart->addSeries(CellRange("A1:C9"));

Chart*scatterChart=xlsx.insertChart(83,3,QSize(300,300));
scatterChart->setChartType(Chart::CT_Scatter);
//Willgeneratethreelines.
scatterChart->addSeries(CellRange("A1:A9"));
scatterChart->addSeries(CellRange("B1:B9"));
scatterChart->addSeries(CellRange("C1:C9"));

Chart*scatterChart_2=xlsx.insertChart(83,9,QSize(300,300));
scatterChart_2->setChartType(Chart::CT_Scatter);
//Willgeneratetwolines.
scatterChart_2->addSeries(CellRange("A1:C9"));

Chart*doughnutChart=xlsx.insertChart(103,3,QSize(300,300));
doughnutChart->setChartType(Chart::CT_Doughnut);
doughnutChart->addSeries(CellRange("A1:C9"));
//![1]

//![2]將xlsx文檔對(duì)象保存為Book1.xlsx文件。
xlsx.saveAs("Book1.xlsx");
//![2]

//保存為Book2.xlsx文件。
Documentxlsx2("Book1.xlsx");
xlsx2.saveAs("Book2.xlsx");
return0;
}

選中項(xiàng)目管理視圖中的example目錄,依次展開,選擇chart目錄,右鍵單擊,選中“構(gòu)建”選項(xiàng),即可對(duì)chart示例演示進(jìn)行構(gòu)建。

然后在chart的編譯構(gòu)建目錄下,將生成如下文件:

8ba2da34-4575-11ed-96c9-dac502259ad0.png

在終端運(yùn)行一下生成的程序(此處是chart):

8bc51ae0-4575-11ed-96c9-dac502259ad0.png

運(yùn)行完成后,將在同級(jí)目錄下創(chuàng)建兩個(gè)文件:如下圖所示:

8bf79204-4575-11ed-96c9-dac502259ad0.png

注:由于在ubuntu編譯構(gòu)建,沒有安裝能打開xlsx的應(yīng)用軟件,故將其拷貝到Windows下使用wps打開。打開后圖表如下圖所示:

8c356296-4575-11ed-96c9-dac502259ad0.png

以上過程是在Ubuntu18.04下進(jìn)行的,如果想讓QtXlsxWriter運(yùn)行于嵌入式linux平臺(tái)上,只需要在QtCreator中選擇編譯構(gòu)建套件時(shí),選擇對(duì)應(yīng)的交叉編譯套件編譯,在編譯完成后,將構(gòu)建出的庫文件復(fù)制到Linux的鏈接庫目錄下(一般為/usr/lib),則可以在嵌入式Linux平臺(tái)上使用QtXlsxWriter了。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • QTcreator
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    6784
  • BIN文件
    +關(guān)注

    關(guān)注

    0

    文章

    26

    瀏覽量

    8247
  • Linux開發(fā)
    +關(guān)注

    關(guān)注

    0

    文章

    31

    瀏覽量

    6875

原文標(biāo)題:Excel表格數(shù)據(jù)導(dǎo)出,這個(gè)庫不錯(cuò)

文章出處:【微信號(hào):嵌入式小生,微信公眾號(hào):嵌入式小生】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    何為Teable多維表格數(shù)據(jù)庫,它僅僅是一個(gè)在線的智能表格嗎?

    表格是一種創(chuàng)新的數(shù)據(jù)管理和協(xié)作工具,它結(jié)合了傳統(tǒng)電子表格的直觀界面與關(guān)系數(shù)據(jù)庫的強(qiáng)大功能。用戶不僅可以像在Excel中一樣在二維
    的頭像 發(fā)表于 10-14 16:13 ?160次閱讀

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統(tǒng)的核心組件,是一種用于控制和數(shù)據(jù)處理的計(jì)算機(jī)硬件,其設(shè)計(jì)旨在嵌入特定設(shè)備中執(zhí)行專門任務(wù)。嵌入式主板如同是設(shè)備
    的頭像 發(fā)表于 09-30 10:05 ?225次閱讀

    嵌入式常用數(shù)據(jù)結(jié)構(gòu)有哪些

    嵌入式編程中,數(shù)據(jù)結(jié)構(gòu)的選擇和使用對(duì)于程序的性能、內(nèi)存管理以及開發(fā)效率都具有重要影響。嵌入式系統(tǒng)由于資源受限(如處理器速度、內(nèi)存大小等),因此對(duì)數(shù)據(jù)結(jié)構(gòu)的選擇和使用尤為關(guān)鍵。以下是
    的頭像 發(fā)表于 09-02 15:25 ?306次閱讀

    嵌入式linux開發(fā)的基本步驟有哪些?

    嵌入式Linux開發(fā)是一個(gè)復(fù)雜的過程,涉及到硬件選擇、操作系統(tǒng)移植、驅(qū)動(dòng)開發(fā)、應(yīng)用程序開發(fā)等多個(gè)方面。以下是嵌入式Linux開發(fā)的基本步驟,以及每個(gè)步驟的說明。 硬件選擇 在開始嵌入式
    的頭像 發(fā)表于 09-02 09:11 ?276次閱讀

    如何提升嵌入式編程能力?

    、SPI、CAN、WIFI、MQTT等多種通信協(xié)議。 4. 使用開發(fā)工具:熟練掌握嵌入式開發(fā)工具,如編譯器、調(diào)試器、仿真器和實(shí)時(shí)操作系統(tǒng)(RTOS)。 5. 閱讀數(shù)據(jù)手冊(cè):仔細(xì)閱讀你所使用的微控制器或
    發(fā)表于 06-21 10:01

    基于AMD、ARM、Intel和NVIDIA技術(shù)構(gòu)建嵌入式工控機(jī)

    嵌入式工控機(jī)提供完全的可靠性、多樣化的外形尺寸、可擴(kuò)展的I/O和各種安裝選項(xiàng),采用工業(yè)級(jí)組件構(gòu)建,并按照精確的要求進(jìn)行成像,保證您獲得可靠且可重復(fù)的嵌入式系統(tǒng)。
    的頭像 發(fā)表于 05-22 17:13 ?463次閱讀
    基于AMD、ARM、Intel和NVIDIA技術(shù)<b class='flag-5'>構(gòu)建</b>的<b class='flag-5'>嵌入式</b>工控機(jī)

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術(shù)集成到嵌入式系統(tǒng)中的一種解決方案。嵌入式系統(tǒng)是一種為特定應(yīng)用而設(shè)計(jì)的計(jì)算機(jī)系統(tǒng),它通常包括處理器、內(nèi)存、外設(shè)接口等組件,并且被嵌入到更大的設(shè)備或系統(tǒng)中,
    的頭像 發(fā)表于 03-15 14:29 ?1118次閱讀

    fpga是嵌入式

    FPGA(現(xiàn)場(chǎng)可編程門陣列)不是嵌入式系統(tǒng),但FPGA在嵌入式系統(tǒng)中有著重要的應(yīng)用。
    的頭像 發(fā)表于 03-14 17:19 ?1978次閱讀

    基于ZYNQ FPGA構(gòu)建嵌入式的模擬計(jì)算板卡

    板卡基于高速400M 采樣AD 和ZYNQ FPGA構(gòu)建嵌入式的模擬計(jì)算板卡, 可用于工業(yè)雷達(dá),行業(yè)雷達(dá)的場(chǎng)合。板卡使用工業(yè)級(jí)芯片。
    的頭像 發(fā)表于 01-09 11:30 ?1103次閱讀
    基于ZYNQ FPGA<b class='flag-5'>構(gòu)建</b><b class='flag-5'>嵌入式</b>的模擬計(jì)算板卡

    用C語言構(gòu)建高效的嵌入式程序

    嵌入式工程師在編寫C語言程序時(shí),需要注重效率和清晰的思路。本文將通過解析經(jīng)典問題“猴子選大王”來展示如何用C語言思維方式構(gòu)建高效、清晰的程序。
    的頭像 發(fā)表于 12-21 09:27 ?561次閱讀

    什么是嵌入式系統(tǒng)?嵌入式系統(tǒng)的具體應(yīng)用

    嵌入式,一般是指嵌入式系統(tǒng)。用于控制、監(jiān)視或者輔助操作機(jī)器和設(shè)備的裝置。
    的頭像 發(fā)表于 12-20 13:33 ?2262次閱讀

    基于ARM的嵌入式電機(jī)控制處理器構(gòu)建的模型設(shè)計(jì)平臺(tái)

    電子發(fā)燒友網(wǎng)站提供《基于ARM的嵌入式電機(jī)控制處理器構(gòu)建的模型設(shè)計(jì)平臺(tái).pdf》資料免費(fèi)下載
    發(fā)表于 11-24 14:39 ?0次下載
    基于ARM的<b class='flag-5'>嵌入式</b>電機(jī)控制處理器<b class='flag-5'>構(gòu)建</b>的模型設(shè)計(jì)平臺(tái)

    嵌入式軟件與生態(tài)系統(tǒng):為嵌入式開發(fā)者提供必要的組件

    Xilinx 提供兩款工具來構(gòu)建和部署嵌入式 Linux 解決方案。這些工具有 Xilinx 的 PetaLinux 和 Yocto 的開源項(xiàng)目。PetaLinux 為用戶提供一個(gè) GUI 來快速
    的頭像 發(fā)表于 10-31 16:59 ?578次閱讀
    <b class='flag-5'>嵌入式</b>軟件與生態(tài)系統(tǒng):為<b class='flag-5'>嵌入式</b>開發(fā)者提供必要的組件

    嵌入式課程設(shè)計(jì)報(bào)告-數(shù)據(jù)排序過程演示

    電子發(fā)燒友網(wǎng)站提供《嵌入式課程設(shè)計(jì)報(bào)告-數(shù)據(jù)排序過程演示.doc》資料免費(fèi)下載
    發(fā)表于 10-26 09:30 ?0次下載
    <b class='flag-5'>嵌入式</b>課程設(shè)計(jì)報(bào)告-<b class='flag-5'>數(shù)據(jù)</b>排序<b class='flag-5'>過程</b>演示

    用Labview開發(fā)的DBC文件轉(zhuǎn)Excel表格文件的VI

    使用Labview軟件開發(fā)的DBC文件轉(zhuǎn)Excel表格文件的VI
    發(fā)表于 10-25 18:23 ?34次下載