Ubuntu下C程式使用xlslib2.3.4去寫excel表格檔案

來源:互聯網
上載者:User

xlslib是一個跨平台的excel表格類庫。也就是說可以在linux下面在C跟C++裡調用它來輸出excel表格檔案。

先去下載源碼,解壓,然後編譯,安裝。

源碼:http://sourceforge.net/projects/xlslib/files/

在終端執行命令:

./configre

make

make check

make install

其中最後 一步make install需要切換到root使用者,才有許可權把標頭檔跟庫檔案寫入到/usr。

這一步之後,預設安裝的庫檔案儲存位置在/usr/local/lib,不在系統預設的lib路徑裡,需要手動把它們拷貝過去

sudo cp /usr/local/lib/libxls* /usr/lib

在寫原始碼的時候,一定要記得包含下面兩個標頭檔,不然會編譯出錯!

#include <wchar.h>
#include <stdbool.h>

關於怎麼使用的例子,2.3.4好像改動比較多,按照網上搜尋到的源碼大多不能使用的,,

大家可以在源碼目錄下面的targets/test/檔案夾查看,

mainC.c是C裡面調用xlslib的例子,mainCPP.CPP是C++調用xlslib的例子。

下面是一個簡單的例子:wb.c

編譯的時候添加xls庫就可以了。

gcc wb.c -o wb -lxls

#include <stdio.h>#include <string.h>#include <wchar.h>#include <stdbool.h>#include <errno.h>#include <xlslib/xlslib.h>int main (int argc, char *argv[]) {workbook *wb;worksheet* ws;wb = xlsNewWorkbook();ws = xlsWorkbookSheet(wb, "sheet1");        xlsWorksheetLabel(ws, 0, 1, "name", NULL);    xlsWorksheetLabel(ws, 0, 2, "US", NULL);    xlsWorksheetLabel(ws, 0, 3, "CN", NULL);    xlsWorksheetLabel(ws, 0, 4, "TR", NULL);    int err = xlsWorkbookDump(wb, "blank.xls");        xlsDeleteWorkbook(wb);if (err != 0){fprintf(stderr, "Dump xls file failed: I/O failure %d.\n", err);return -1;}    return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.