使用VS2015编译xlslib库
环境:
win7_x64,VS2015
开始:
一、下载xlslib库
解压到一个指定目录,如E:\library\xlslib-package-2.5.0
二、创建VS2015项目
1. 将"E:\library\xlslib-package-2.5.0\xlslib\xlslib\build\msvc2012"文件夹复制一份,并重命名为msvc2015
2. 使用VS2015打开"E:\library\xlslib-package-2.5.0\xlslib\xlslib\build\msvc2015\xlslib.sln",打开期间会提示是否升级到VS2015编译器,点击升级。
三、配置VS2015项目
1. 修改"xlslib_dll"项目
"xlslib_dll"项目 -> "编辑 xlslib_dll.vcxproj",将重复的"<ClCompile Include="..\..\src\xlslib\formula.cpp" />"项,删除一个,然后重新加载项目即可。
"xlslib_dll"项目 -> "C/C++" -> "预处理器" -> "预处理器定义" 添加 "_SILENCE_STDEXT_HASH_DEPRECATION_WARNINGS"
"xlslib_lib"项目 -> "属性" -> "生成事件" -> "后期生成事件" -> "命令行" 替换为
echo $(SolutionDir)bin/x64_MSVC2015.$(Configuration)\createDLL -M$(Platform) -n$(OutDir)$(ProjectName).map -l$(IntDir) -i$(OutDir)$(ProjectName).lib -W$(SolutionDir)obj/$(ProjectName)_$(Platform)_MSVC2015.$(Configuration)\
$(SolutionDir)bin/x64_MSVC2015.$(Configuration)\createDLL -M$(Platform) -n$(OutDir)$(ProjectName).map -l$(IntDir) -i$(OutDir)$(ProjectName).lib -W$(SolutionDir)obj/$(ProjectName)_$(Platform)_MSVC2015.$(Configuration)\
"xlslib_lib"项目 -> "属性" -> "常规" -> "输出目录" -> 替换为 "$(SolutionDir)bin/$(Platform)_MSVC2015.$(Configuration)\"
"xlslib_lib"项目 -> "属性" -> "常规" -> "中间目录" -> 替换为 "$(SolutionDir)obj/$(ProjectName)_$(Platform)_MSVC2015.$(Configuration)\"
2. 修改"createDLL"项目
"createDLL"项目 -> "C/C++" -> "预处理器" -> "预处理器定义" 添加 "_SILENCE_STDEXT_HASH_DEPRECATION_WARNINGS"
"createDLL"项目 -> "属性" -> "常规" -> "输出目录" -> 替换为 "$(SolutionDir)bin/$(Platform)_MSVC2015.$(Configuration)\"
"createDLL"项目 -> "属性" -> "常规" -> "中间目录" -> 替换为 "$(SolutionDir)obj/$(ProjectName)_$(Platform)_MSVC2015.$(Configuration)\"
四、修改编译错误
1. 修改"acconfig.win32.h"文件
删除230行"typedef __int8 int8_t;"
2. 修改note.h文件
将46行"uint16_t sheet_notes"替换为"uint16_t sheet_notess"
3. 修改note.cpp文件
将342行"last_sheet.sheet_notes"替换为"last_sheet.sheet_notess"
将355行"sn.sheet_notes"替换为"sn.sheet_notes"
将358行"sn.sheet_notes"替换为"sn.sheet_notes"
4. 修改formula.cpp文件
将917行"function_property p = (function_property) {CELLOP_AS_VALUE, A_UNKNOWN};"替换为"function_property p{CELLOP_AS_VALUE, A_UNKNOWN};"
5. 修改createDLL.cpp文件
在385行添加"__xmm@",否则编译"xlslib_dll"项目会出现"error LNK2001: 无法解析的外部符号 __xmm@00000000000000000000000000000002"
"__xmm@00000000000000000000000000000002"符号是在构造函数初始化列表中枚举类型赋初始值时,VS2015编译时自动创建的,在VS2010中不会创建这个符号,添加到filterSymbols数组是为了将不需要导出的符号过滤掉。
使用VS2015编译xlslib库的更多相关文章
- [转]Windows下使用VS2015编译openssl库
转自:http://blog.csdn.net/alger_magic/article/details/52584171 目标:编译vs环境下openssl库 工具: 1. 编译环境win10+vs2 ...
- Qt 5.6 5.8 vs2015 编译静态库版本(有全部的截图)good
安装Qt 去Qt官网下载Qt安装包 安装Qt和源码,一定要勾选source选项 添加bin到系统变量 工具 需要python3和 perl. vs2015 第三方工具,到官方下载安装 在命令行 ...
- vs2015 编译boost库
1.下载boost官网安装包. https://dl.bintray.com/boostorg/release/1.66.0/binaries/ 注意:这里一定要选择好boost版本 如: boos ...
- VS2015编译gdal库
gdal下载地址:http://trac.osgeo.org/gdal/wiki/DownloadSource 修改nmake.opt中的一些配置.1. GDAL_HOME = “C:\warmerd ...
- VS2015编译GDAL库出现宏重复定义 snprintf: 宏重定义
E:\OpenSourceGraph\gdal-1.10.0\gdal\port cpl_config.h 20行 #define HAVE_VPRINTF 1#define HAVE_ ...
- VS2015编译gdal库 debug
nmake -f makefile.vc DEBUG=1nmake /f makefile.vc installnmake /f makefile.vc devinstal E:\Visual Stu ...
- vs2015编译各种库
1.编译libcurl https://www.jianshu.com/p/f82d3d18da93
- VS2015编译OpenSSL
概述 OpenSSL 是一个开源的第三方库,它实现了 SSL(Secure SocketLayer)和 TLS(Transport Layer Security)协议,被广泛企业应用所采用.对于一般的 ...
- VS2015编译Qt5.7.0生成支持XP的静态库(很不错)
一.编译工具 1.VS2015 编译Qt5.7.0的所需VS版本:Visual Studio 2013 (Update1)或Visual Studio 2015 (Update2).因为Update补 ...
随机推荐
- 2018工业信息安全技能大赛华东赛区初赛 第2题 writeup
2018工业信息安全技能大赛华东赛区初赛 第2题 解题思路 本题主要考察点是对常见工控协议的理解(modbus/tcp和s7comm),题目目标是寻找出报文中某条异常报文流量.很让人疑惑的是,题目中并 ...
- 1019. General Palindromic Number (20)
生词以及在文中意思 forward 向前地 backward 向后地 palindromic 回文的 base 基数(如十进制的10 和二进制的2) numeral system 数制 decimal ...
- 为什么使用zookeeper?
随着应用规模的迅速扩张,单台机器的部署已经难以支撑用户大规模.高并发的请求了, 因此服务化.集群化.分布式概念应运而生. 针对这种场景,人们通常使用的做法就是将软件按照模块进行拆分,形成独立的子系统, ...
- Python机器学习(基础篇---监督学习(集成模型))
集成模型 集成分类模型是综合考量多个分类器的预测结果,从而做出决策. 综合考量的方式大体分为两种: 1.利用相同的训练数据同时搭建多个独立的分类模型,然后通过投票的方式,以少数服从多数的原则作出最终的 ...
- session_id() , session_start(), $_SESSION["userId"], header("Location:homeLogin.php"); exit 如果没有登录, 就回登录页
if(!session_id()) session_start(); header("Content-type:text/html;charset=utf-8"); if (emp ...
- 三,用户交互方式与python基本数据类型
一.与用户交互 input python2中:用户输入什么类型的数据,就储存为什么类型的数据.比如输入数字则储存为整型,输入符号则存储为字符串型.raw_input会将所有输入的类型转换为字符串型. ...
- @RequestMapping、@ResponseBody和@RequestBody的使用
使用SSM框架进行Web开发时,经常在Controller中遇到@RequestMapping.@ResponseBody和@RequestMapping注解. 1.@RequsetMapping注解 ...
- Linux 驱动——Led驱动2
led_drv.c驱动文件: #include <linux/module.h>#include <linux/kernel.h>#include <linux/init ...
- C#创建、读写、增加、删除XML操作
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...
- 常用css
边框 css 基本设置:border:1px solid #d2d2d2; 风格有:solid=>实线 double=>双实线 dotted=>点状 dashed=> ...