在安装jsdom模块的过程中遇到这么一个MSB4025错误:(win8.1 下,已经安装了vs2013 for desktop express版)
error MSB4025: 未能加载项目文件,给定编码中的字符无效
在网上查了一些资料,说是因为编码的问题,因为在windows下使用,用户名是中文,导致在生成vcxproj文件时,有些依赖路径里包含了中文字符。好吧,我承认我安装模块的路径的确是包含中文名称......
windows下的中文默认用的是GBK编码,而vcxproj文件默认的编码方式是utf-8。node的gyp工具,并没有很好的处理多语言编码的问题。这样导致生成的vcxproj文件是ANSI编码,内部的中文字符是GBK编码,等到调用VS 2013编译模块时,就会导致VS2013无法正确使用vcxproj文件,导致编译安装失败。
nodejs的gyp工具使用的python,在安装目录下可以找到gyp相关的python代码,修改其中用于生成vcxproj的代码,使其用utf-8编码生成文件内容并存储,即可解决此问题。
网上找到资料说是修改 C:\Program Files (x86)\nodejs\node_modules\npm\node_modules\node-gyp\gyp\pylib\gyp>下的 easy_xml.py文件(这里的 ‘C:\Program Files (x86)\nodejs’指的是本人nodejs的安装路径,实际操作中要换成对应的路径,一般是‘C:\Program Files\nodejs‘)
找到 “# It has changed, write it”这一行,将下面的判断代码修改,原来是:
# It has changed, write it if existing != xml_string: f = open(path, 'w' ,'utf_8_sig') f.write(xml_string) f.close()
换成下面的代码:
# It has changed, write it if existing != xml_string: if path.endswith('vcxproj'): #use utf_8 encoding to generate vcxproj file f = codecs.open(path, 'w', 'utf_8_sig') #convert GBK string to Unicode string to ensure the later utf_8 encoding f.write(xml_string.decode('gbk')) else: f = open(path, 'w') f.write(xml_string) f.close()
值得注意的是,代码中使用到了“codecs.open”,所以要再开头处引入codecs,要不然会报错说变量找不到,在开头处加上:
import codecs
完成后保存,在运行一下安装jsdom的命令,发现已成功安装。