libxls库的编译以及基于Visual studio的配置
最近有一个需求在windows处理xls,所以就需要libxls这个库,调查了一下,基于C++的库的解析情况如下:

所以最理想的就是Libxlsd个开源的方案
基于历史整理的 libxls 在 MinGW 下的编译步骤
前提条件
- 系统:Windows(你的情况)。
- 工具:已安装 MSYS2(
C:\msys64)。 - 源码:libxls 1.6.3,已下载并解压到
/Downloads/libxls-1.6.3/libxls-1.6.3。 - 目标:生成
libxlsreader-8.dll,包括 Debug 版本。
编译步骤
1. 准备 MSYS2 环境
-
更新 MSYS2:
- 打开任意 MSYS2 终端(如 MSYS 终端):
C:\msys64\msys2_shell.cmd -msys - 更新系统:
pacman -Syu- 若提示关闭终端,关闭后重新打开并再次运行
pacman -Syu。
- 若提示关闭终端,关闭后重新打开并再次运行
- 打开任意 MSYS2 终端(如 MSYS 终端):
-
安装基本工具:
- 在 MSYS 终端安装 autotools:
pacman -S autoconf automake libtool autoconf-archive make - 在 MinGW64 终端安装编译器:
C:\msys64\msys2_shell.cmd -mingw64 pacman -S mingw-w64-x86_64-gcc mingw-w64-x86_64-make
- 在 MSYS 终端安装 autotools:
2. 配置源码
-
进入源码目录:
- 在 MinGW64 终端:
cd /Downloads/libxls-1.6.3/libxls-1.6.3
- 在 MinGW64 终端:
-
生成
configure文件:- 切换到 MSYS 终端(autotools 需要 POSIX 环境):
C:\msys64\msys2_shell.cmd -msys cd /Downloads/libxls-1.6.3/libxls-1.6.3 - 运行:
autoreconf -i - 注意:若报错(如
AX_CXX_COMPILE_STDCXX_11),确保autoconf-archive已安装。
- 切换到 MSYS 终端(autotools 需要 POSIX 环境):
3. 配置编译选项
-
打开 MinGW64 终端:
C:\msys64\msys2_shell.cmd -mingw64 cd /Downloads/libxls-1.6.3/libxls-1.6.3 -
配置 Release 版本(默认):
./configure --prefix=/mingw64 MAKE=mingw32-make -
配置 Debug 版本:
- 添加调试符号并禁用优化:
./configure --prefix=/mingw64 MAKE=mingw32-make CFLAGS="-g -O0" CXXFLAGS="-g -O0" LDFLAGS="-g" - 可选:若需静态库:
./configure --prefix=/mingw64 --disable-shared --enable-static MAKE=mingw32-make CFLAGS="-g -O0" CXXFLAGS="-g -O0"
- 添加调试符号并禁用优化:
4. 编译
-
清理旧构建(可选):
mingw32-make clean -
编译:
mingw32-make- 注意:若遇到
spawnv类型冲突错误,见下文“常见问题”。
- 注意:若遇到
5. 安装
-
安装库和头文件:
mingw32-make install -
验证输出:
- 检查生成的库:
ls /mingw64/bin/libxlsreader-8.dll # 动态库 ls /mingw64/lib/libxlsreader.dll.a # 导入库 ls /mingw64/lib/libxlsreader.la # Libtool 元数据 - 检查头文件:
ls /mingw64/include/libxls - Debug 版本验证:
objdump -h /mingw64/bin/libxlsreader-8.dll | grep debug
- 检查生成的库:
常见问题及解决
1. make: command not found
- 现象:运行
make时出错。 - 解决:
pacman -S mingw-w64-x86_64-make alias make='mingw32-make' # 临时别名- 或直接用:
./configure --prefix=/mingw64 MAKE=mingw32-make mingw32-make
- 或直接用:
也可以使用以下这个指令亲测:
CC='gcc' ./configure --build=mingw64 --prefix=/mingw64 --enable-static --enable-shared MAKE=mingw32-make && make install
2. AX_CXX_COMPILE_STDCXX_11 语法错误
- 现象:
./configure: line 19757: syntax error near unexpected token `,' - 解决:
- 安装
autoconf-archive:pacman -S autoconf-archive # 在 MSYS 或 MinGW64 终端 - 重新运行:
autoreconf -i # 在 MSYS 终端
- 安装
3. spawnv 类型冲突
- 现象:
C:/msys64/mingw64/include/process.h:196:28: error: conflicting types for 'spawnv' - 解决:
- 修改代码:
- 编辑
src/xls2csv.c、test/test.c、test/test2.c和cplusplus/main.cpp:- rval = (int) _spawnv(_P_WAIT, lt_argv_zero, (const char * const *) newargz); + rval = (int) _spawnv(_P_WAIT, lt_argv_zero, (char *const *) newargz); - 或移除
unistd.h,替换为:#include <process.h>
- 编辑
- 禁用测试程序和
xls2csv(推荐,若只需库):- 编辑
Makefile.am:#bin_PROGRAMS = xls2csv #noinst_PROGRAMS = test_libxls test2_libxls #if HAVE_CXX11 #noinst_PROGRAMS += test_cpp #endif - 重新生成:
autoreconf -i # 在 MSYS 终端 ./configure --prefix=/mingw64 MAKE=mingw32-make mingw32-make
- 编辑
- 修改代码:
4. Makefile.am 警告
- 现象:
Makefile.am:35: warning: variable 'xls2csv_SOURCES' is defined but no program or library has 'xls2csv' as canonical name - 解决:
- 若禁用程序,忽略警告。
- 若需编译程序,确保
bin_PROGRAMS和noinst_PROGRAMS未注释。
生成的库
- Release 版本:
/mingw64/bin/libxlsreader-8.dll/mingw64/lib/libxlsreader.dll.a/mingw64/lib/libxlsreader.la
- Debug 版本:
- 同上,但文件包含调试符号(用
-g -O0配置)。
- 同上,但文件包含调试符号(用
使用示例
-
C 调用(MinGW):
gcc -I/mingw64/include/libxls -L/mingw64/bin -lxlsreader test.c -o test.exe ./test.exe -
Visual Studio:
- 需用 MSVC 重新编译,或将
.dll放入项目目录并配置头文件。
- 需用 MSVC 重新编译,或将
总结
以上步骤在你的环境下(MSYS2 MinGW64,路径 /Downloads/libxls-1.6.3/libxls-1.6.3)可生成 libxlsreader-8.dll。Debug 版本需添加 CFLAGS="-g -O0"。若只需库,禁用测试程序可简化流程。按步骤操作即可成功编译!
第二步骤就是将得到的dll转为.lib ,供visual studio引用
使用 dlltool 生成 .def 文件再转换
(如果 reimp 不可用(我是没找到合适安装包和路径)可通过以下步骤手动转换)
- 生成 .def 文件:
gendef libxlsreader-8.dll
- 使用 dlltool 生成 .lib:
dlltool -d libxlsreader.def -D libxlsreader.dll -l libxlsreader.lib -k
相关文章:
libxls库的编译以及基于Visual studio的配置
最近有一个需求在windows处理xls,所以就需要libxls这个库,调查了一下,基于C的库的解析情况如下: 所以最理想的就是Libxlsd个开源的方案 基于历史整理的 libxls 在 MinGW 下的编译步骤 前提条件 系统:Windows&#…...
OpenHarmony构建系统-GN与子系统、部件、模块理论与实践
理论 OpenHarmony源码体系 OpenHarmony的源码架构基于模块化设计,为了方便系统的功能的增加和裁剪,设计了基于GN构建的模块系统。整个模块可从大到小划分为产品(product)、领域/子系统集(domain)、子系统(sub system)、部件(component)、模块/组件(modu…...
kafka+spring cloud stream 发送接收消息
方案 1:使用旧版 StreamListener(适用于 Spring Cloud Stream < 2.x) 1. 添加依赖(pom.xml) <!-- Spring Cloud Stream Kafka Binder --> <dependency> <groupId>org.springframework.clo…...
使用ArcGIS Pro自动矢量化水系
在地理信息系统(GIS)领域,自动矢量化是一项至关重要的技术,它能够将栅格图像中的要素转换为矢量数据,从而方便后续的分析和处理。本文将详细介绍如何使用ArcGIS Pro自动矢量化水系,适用于那些颜色相对统一、…...
在PyCharm中运行Jupyter Notebook的.ipynb文件及其pycharm软件的基础使用
(注意需使用PyCharm专业版,学生、教师可以申请免费使用:https://www.jetbrains.com/shop/eform/students) 1. pycharm2024版汉化 https://blog.csdn.net/m0_74103046/article/details/144560999 2. pycharm中的python控制台和J…...
实验 Figma MCP + Cursor 联合工作流
开源项目 Figma-Context-MCP 介绍 使用此 Model Context Protocol 服务器授予 Cursor 对 Figma 文件的访问权限。 当 Cursor 可以访问 Figma 设计数据时,它比粘贴屏幕截图等其他方法更能准确地进行代码转化。 开源仓库: GLips/Figma-Context-MCP 具体…...
移植live555 上的 rtsp
一、V4L2视频采集模块(完整示例) #include <linux/videodev2.h> #include <sys/ioctl.h> #include <fcntl.h>// 初始化V4L2摄像头 int init_v4l2_camera(const char* dev_path, int width, int height) {int fd open(dev_path, O_RD…...
Web Worker终极优化指南:4秒卡顿→0延迟的实战蜕变
💡 导读:从4秒卡顿到丝滑响应 真实痛点场景:当斐波那契数列计算量达10亿次时,页面完全冻结4.2秒!通过Web Worker优化后,UI响应时间降至16ms以内。本文手把手带您实现性能蜕变! 一、Web Worker核…...
redis中的Lua脚本,redis的事务机制
lua脚本的特点 lua脚本可以操作redis数据库,并且脚本中的代码满足原子性,要么全部被执行,要么全部不执行 lua脚本的语法 脚本示例 lua脚本的草稿: 最终的lua脚本 lua脚本在java里调用的方法 RedisTemplete类里有一个方法&…...
CPU多级缓存与缓存一致性协议
CPU多级缓存与缓存一致性协议 CPU多级缓存和缓存一致性协议是计算机体系结构中优化性能与保证数据正确性的核心机制。以下从缓存层级设计、工作原理、一致性协议(如MESI)及其实现细节展开说明。 一、为什么需要多级缓存? CPU的计算速度远高…...
Apifox 增强 AI 接口调试功能:自动合并 SSE 响应、展示DeepSeek思考过程
在现代的API接口调试中,效率和精确性对于开发者和测试人员来说至关重要。Apifox,作为一款功能强大的API管理和调试工具,近年来不断提升其用户体验和智能化功能。最近,Apifox 推出了增强版的AI接口调试功能,其中包括自动…...
【电机控制】42步进电机+arduino:WHEELTEC_MS42DDC
轮趣科技 42步进电机arduino:WHEELTEC_MS42DDC 接线方式: WHEELTEC_MS42DDC有两个接口, 一端接口连接配套的DC电源,另外一端只需要用三根线,一根负极连接ardino 的GND,然后把该端口的tx和rx连接到arduino的rx和tx,下…...
使用LangChain构建第一个ReAct Agent
使用LangChain构建第一个ReAct Agent 准备环境 使用Anaconda 安装python 3.10 安装langchain、langchain_openai、langchain_community (安装命令 pip install XXX) 申请DeepSeek API:https://platform.deepseek.com/api_keys(也…...
萝卜头笔作文赏析
在遥远的无寻王国,有这么一支小小的笔诞生了,人们见它又短又小,于是就给它取名叫萝卜头笔。萝卜头笔渐渐长大了,除了身子变粗些,其他什么都没变。一天,萝卜头笔来到了深山老林,那里枝叶繁茂&…...
RT-Thread+STM32L475VET6——USB鼠标模拟
文章目录 前言一、板载资源二、具体步骤1.配置icm20608传感器2.打开CubeMX进行USB配置3. 配置USB3.1 打开USB驱动3.2 声明USB3.3 剪切stm32xxxx_hal_msp.c中的void HAL_PCD_MspInit(PCD_HandleTypeDef* hpcd)和void HAL_PCD_MspDeInit(PCD_HandleTypeDef* hpcd)函数至board.c3.…...
rust 安全性
Rust 是 静态类型(statically typed) 语言, 也就是说在编译时就必须知道所有变量的类型, 这一点将贯穿整个章节。 C/C的安全问题 内存的不正确访问引发的内存安全问题 由于多个变量指向同一块内存区域导致的数据一致性问题 由于…...
大模型驱动的围术期质控系统全面解析与应用探索
目录 一、引言 1.1 研究背景与意义 1.2 研究目的与方法 1.3 研究创新点 二、大模型技术与围术期管理概述 2.1 大模型技术原理与发展现状 2.2 围术期管理流程与挑战 三、大模型在术前的应用 3.1 病历内涵质控 3.2 智能医学问答与知识查询 3.3 疾病风险预测与评估 3.…...
中兴B863AV3.2-T/B863AV3.1-T2/B863AV3.1-T2K_电信高安_S905L3A-B_安卓9.0_线刷固件包
中兴B863AV3.2-T/B863AV3.1-T2/B863AV3.1-T2K_电信高安_S905L3A-B_安卓9.0_线刷固件包 B863AV3.2-T B863AV3.1-T2 已知可通刷贵州、江苏、贵州、北京、河南、陕西等省份。 线刷方法:(新手参考借鉴一下) 1、准备好一…...
Android Binder机制
Binder是IPC(进程间通信)的一种机制,它允许不同的应用或系统服务在不同的进程中安全地交换数据。Binder的核心原理是基于客户端-服务器模型(C/S架构)。 一、Binder的定义 1. Binder是Android中的一个类,它继承了IBind…...
【算法】初等数论
初等数论 模 取余,遵循尽可能让商向0靠近的原则,结果的正负和左操作数相同 取模,遵循尽可能让商向负无穷靠近的原则,结果的正负和右操作数相同 7/(-3)-2.3,产生了两个商-2和-3,取…...
接口测试中缓存处理策略
在接口测试中,缓存处理策略是一个关键环节,直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性,避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明: 一、缓存处理的核…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...
《从零掌握MIPI CSI-2: 协议精解与FPGA摄像头开发实战》-- CSI-2 协议详细解析 (一)
CSI-2 协议详细解析 (一) 1. CSI-2层定义(CSI-2 Layer Definitions) 分层结构 :CSI-2协议分为6层: 物理层(PHY Layer) : 定义电气特性、时钟机制和传输介质(导线&#…...
HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...
现代密码学 | 椭圆曲线密码学—附py代码
Elliptic Curve Cryptography 椭圆曲线密码学(ECC)是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础,例如椭圆曲线数字签…...
PL0语法,分析器实现!
简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...
【C语言练习】080. 使用C语言实现简单的数据库操作
080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...
MySQL 8.0 OCP 英文题库解析(十三)
Oracle 为庆祝 MySQL 30 周年,截止到 2025.07.31 之前。所有人均可以免费考取原价245美元的MySQL OCP 认证。 从今天开始,将英文题库免费公布出来,并进行解析,帮助大家在一个月之内轻松通过OCP认证。 本期公布试题111~120 试题1…...
今日科技热点速览
🔥 今日科技热点速览 🎮 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售,主打更强图形性能与沉浸式体验,支持多模态交互,受到全球玩家热捧 。 🤖 人工智能持续突破 DeepSeek-R1&…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
