没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|其它|编辑:郝浩|2009-04-27 09:42:25.000|阅读 3316 次
概述:Excel中有一列数据是数字和文本方式混合排列的,在用ADO导入数据时就会出现部分数据不能导入的问题
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
Excel中有一列数据是数字和文本方式混合排列的,在用ADO导入数据时就会出现部分数据不能导入的问题
解决这个问题 首先想到的是常用的数字转换为文本格式的方法 WorkSheet.Columns[1].NumberFormatLocal:='@';
几行代码一敲,测试发现没效果,就马上开始 baidu,google 铺天盖地的搜索。。。
没怎么搜索就找到了excel 中有用分列方法将整列数据文本格式化的方法:数据->分列->列数据格式->文本
录制下的宏代码如下:
接下来将VBA宏代码翻译成delphi代码:
一编译才发现 Array(1,2) 语法错误,于是将其改成delphi 中的数组格式 Array[0..1] of Integer=(1,2) ,
编译还是报错,发现是因为是Delphi调用OLE自动化控制器操纵Excel,该方法只能出现OleVariant类型的参数,马上找资料看有没有OleVariant类型的数组,一下就找到了马上改了代码换上去:
满以为这下问题应该解决了吧,编译通过,测试发现点都么反应,郁闷了。。。
到底是哪点的原因呢?开始排查问题中。。。
第一个可能的原因,excel 宏写错了?反复测试,都能正常运行,效果明显。
第二个可能的原因,delphi OLE操纵Excel 失效?测试了其他Ole代码,都能正常运行,没有问题。
现在就剩下一个比较确定的问题了,WorkSheet.Selection.TextToColumns 这个方法的问题。
搜索引擎中输入"delphi TextToColumns" 搜出来的结果寥寥可数,遇到这个问题的很少,提的问题大多都没人回答,
许多人甚至不知所云,千辛万苦找到MSDN中的帮助中有 C# 调用 excel 这个方法的示例,但是关键地方就是数组参数
他用空值代替了:
反复的看帮助中对 FieldInfo 的描述:
一个数组,包含各个数据列的分析信息。解释取决于 DataType 的值。当对数据进行分隔时,此参数是一个由两元素数组组成的数组,每个两元素数组都指定特定列的转换选项。第一个元素是列号(从 1 开始),第二个元素是指定如何分析列的 XlColumnDataType 常数之一。
可以是下列 XlColumnDataType 值之一:
只有当安装并选择了台语支持时,才能使用 xlEMDFormat。xlEMDFormat 指定所使用的台语纪元日期。
列说明符可以采用任何顺序。如果对于输入数据中的特定列,给定的列说明符不存在,则用 xlGeneralFormat 设置对列进行分析。
如果源数据具有固定宽度的列,则每个两元素数组中的第一个元素都指定该列中的起始字符位置(以整数形式指定;0(零)是第一个字符)。两元素数组的第二个元素将该列的分析选项指定为从 1 至 9 的数字,如上面列出的那样。
还是不明所以。。。接下来就是漫长的碰运气时间。。。。 改不同的参数运行测试,反复N次,每次都是失望的结果。就这样被这个问题折磨了3天多的时间,我绝望了,很想放弃,因为我至少找到了数据导入出现空行的原因和解决方法,只是不能用程序实现,每次导入数据前人工操作excel将数据格式化也不是太麻烦。但在花了这么多时间和精力后我能放得下吗?就这样心甘情愿的认输?对自己说,我做不到?不!一定能行,我还没有失败,相反已经成功了一半了,剩下的那一半只是时间和灵感问题,这时候放弃了才是真的失败了。稍微放松下,暂时什么都不想,等会一定把你搞定 。打几盘魔兽先 这一刻终于来临,一段代码突然给我带来了灵感,我是不是应该把参数类型带进去?虽然资料和帮助都没提到,但是语法上应该是没问题的,说做就做: 运行,测试,通过 !!!喔耶,完美解决,perfect ! 怎一个爽字了得。。。哈哈哈哈哈哈 编程也需要不抛弃,不放弃,还有一点点灵感。我能!无所不能!
var a:OleVariant;
a:=VarArrayCreate([0,1],varInteger);
a[0]:=1;
a[1]:=2;
WorkSheet.Columns[4].Select;
WorkSheet.Columns[4].TextToColumns(WorkSheet.Cells[1,4],DataType:=xlDelimited,TextQualifier:=xlDoubleQuote,FieldInfo:=a);
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:博客园面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号