2

我最近发现了这个 C 库(http://libxlsxwriter.github.io/),并尝试将它与 R 一起使用。

让 C 库自己工作并不困难。我下载zliblibxlsxwriter使用msys2,并makelibxlsxwriter文件夹中运行。

现在我可以运行这个 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,但我猜我需要的不止这些。

4

2 回答 2

2

您可能想尝试 Continuum 的 Anaconda R 软件包。他们相当直接地使用 MSYS2 包。工具链包称为 m2w64-toolchain,而 posix 包有时也可用于构建 R 包。

conda install -c r r-essentials m2w64-toolchain posix

免责声明:我为 Continuum 工作,但我也在 MSYS2 上工作。

于 2016-07-20T18:08:14.203 回答
0

它不会很优雅,但如果 4 年没有人找到优雅的解决方案,你不妨使用:

shell("cc test.c -o test -lxlsxwriter -lz")

这将有助于这部分以及任何小的需要立即访问 xlsx 功能

在这一点上,我只是想让 hello-world 示例从 R 中运行。

您可能已经知道这一点,但以防万一您没有想到使用该shell()命令。

于 2020-05-02T13:08:31.653 回答