最近项目由于要保存较大量的数据,而开发工具是VC,便从网上下了几个能够读写EXCEL文件的类。使用对比后还是觉得Basicexcel又快又好也够用。
网上评论说这个类唯一的缺点是不能很好的支持中文,其实该类对中文支持的接口也是很完备的,问题就出在有时对wchar_t类型的参数处理不好。
比如在VC中,字符串的编码默认情况下都是使用ASCII码,不论是中文还是英文。只是英文占一个字节,而中文占两个字节,如
char *str = "Hi中国"
其字符长度为1+1+2+2=6个字节。Basicexcel中提供读写中文的接口其参数为wchar_t双字节类型,因此如果参数传递时处理不完善就会有问题。最快而又方便编程的解决方法便是稍微改变两个函数:
函数1:将void SetWString(const wchar_t* str)的参数改为char*类型并修改函数体
void BasicExcelCell::SetWString(const char* str)
{
wchar_t *pUnicode = NULL;
size_t length = MultiByteToWideChar(CP_ACP,MB_COMPOSITE,str,-1,NULL,