我最近发现了这个 C 库(http://libxlsxwriter.github.io/),并尝试将它与 R 一起使用。
让 C 库自己工作并不困难。我下载zlib
并libxlsxwriter
使用msys2
,并make
在libxlsxwriter
文件夹中运行。
现在我可以运行这个 Hello-World 示例,我们称之为test.c
:
#include "xlsxwriter.h"
void main() {
lxw_workbook *workbook = workbook_new("myexcel.xlsx");
lxw_worksheet *worksheet = workbook_add_worksheet(workbook, NULL);
int row = 0;
int col = 0;
worksheet_write_string(worksheet, row, col, "Hello me!", NULL);
workbook_close(workbook);
}
test.c
现在我可以通过运行编译:
cc test.c -o test -lxlsxwriter -lz
然后运行可执行文件:
./test
现在我有一个 Hello-World excel 文档。
让它与 R 一起工作要棘手得多。如果我只是运行:
R CMD SHLIB test.c
我收到此错误:ibxlsxwriter/include/xlsxwriter/common.h:19:42: fatal error: xlsxwriter/third_party/queue.h: No such file or directory
#include "xlsxwriter/third_party/queue.h"
然而,当我检查时,文件显然在那里。
关于如何将此 C 库与 R 连接的任何建议?在这一点上,我只是想让 hello-world 示例从 R 中运行。
xlsxwriter
在文件夹中开始构建一个包,inst
然后尝试编写一个makevars
可以xlsxwriter
正确编译的包会是更好的方法吗?我知道我必须包括在内PKG_CPPFLAGS = -I../inst/libxlsxwriter
,但我猜我需要的不止这些。