今天在使用excel.exe导出类来读取excel文件内容,这个的确很强大,但是用的时候每遇到一个问题都是新的问题,虽然以前也稍有接触,但是VC环境下和我以前用工具思维方式不同。初次使用,难免磕磕碰碰,整体还算顺利,但是在我在类上右击选择new atl object后,com初始化失败了,之前调用函数CoInitialize(NULL)一直很顺利,后来就不行了,在网上搜到的资料都是跟线程相关的,跟我的问题原因无关。我再新打开一个工程,打开其他的项目都很正常。找不到解决办法了,无奈之下,只好新建一个工程,把原来的东西全都加载进去了。这样可以暂时解决问题。
我写了个类,里面调用了继承自CArray的模板类创建的二维数组,反复测试学习了一天,终于可以顺利将excel表格中的数据读到二维数组中,并可以获取出来,然后赋值给CListCtrl。我在主对话框类中传CListCtrl类的指针进去,跟踪一下,赋值都很正常,但是在对话框类中显示时顺序却是反的。不太明白这个原因,也许是跟堆栈有关系,从入栈到出栈顺序正好是相反的。暂且在赋值的时候把顺序倒过来,可以显示出来正确的顺序吧。
突然发现了CListCtrl顺序颠倒的原因了,其实之前使用CTabCtrl时也遇到过顺序反的问题,其实是我自己的错,InsertColumn(0,,);第一个参数应该是i,我写成了,所以每次插入一个新的列时,这个新列就成为了第一列,直至最后显示出来时正好和原本的插入顺序相反,同样才错误犯了两次。