当前位置 > 首页 > Asp.net

delphi中操作Excel用分列方法将数字转换为文本格式

2009-4-25 16:05:00来源:Asp.net

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 的描述:

FieldInfo
类型:System..::.Object

一个数组,包含各个数据列的分析信息。解释取决于 DataType 的值。当对数据进行分隔时,此参数是一个由两元素数组组成的数组,每个两元素数组都指定特定列的转换选项。第一个元素是列号(从 1 开始),第二个元素是指定如何分析列的 XlColumnDataType 常数之一。

可以是下列 XlColumnDataType 值之一:

只有当安装并选择了台语支持时,才能使用


  • How to 301 Permanent Redirect in ASP.NET

    2010-2-1 12:02:00

    In the next release of the .NET Framework (.NET Framework 4.0) there is a new response method for p

  • 一起学习ArcEngine(7)上/下一个视图

    2009-9-24 0:54:00

    摘要: 上一个视图命令可以快速的回退到最后一次地图操作以前的地图范围, 下一个视图命令和上一个视图命令恰好相反。举个简单的例子,我现在看北京市的地图,同事甲过来想看看上海的地图,刚看不久,同事乙过

  • Entity Framework 学习初级篇1--EF基本概况

    2009-5-7 21:07:00

    最近在学习研究微软的EF,通过这时间的学习研究,感觉这个EF目前来说还不是很完善,半成品。不过,据说在.Net4.0中,微软将推荐使用此框架,并会有所改善。而且,现在基本上所有数据库均提供了对EF的

  • 判定类型

    2010-1-20 20:53:00

    阅读: 186 评论: 1 作者: 司徒正美 发表于 2010-01-20 18:56 原文链接 目前最精确的判定方法(不包括自定义类型) var is = fu

  • vc.net如何读取文本文件特定位置的数据?

    2010-12-9 12:46:00

    本打算使用StreamReader,然后更改其基础流的偏移量,如下语句 StreamReader^sr= gcnew StreamReader( 1.txt ) ; Int32 of

  • JQuery插件-多选(适用于GridView,DataList,Repeater以及其他)

    2007-6-12 18:36:00

    摘要: JQuery是一个非常强大的JavaScript Framework,用它可以更方便的查找,操作html元素。尤其是提供了ready事件,从此不再为body的onload事件而郁闷不已。 阅

  • Uploading and storing files in SQL using ASP.NET

    2010-2-22 9:58:00

    Version: VS2008 SP1 The sample code at the bottom of this post shows you how to upload files and

  • 【原创】AccessHelper

    2009-4-18 21:03:00

    摘要: 最近的一个项目中用到了Access,于是自己写了一个AccessHelper,现把代码贴出来,欢迎大家提出宝贵意见! 阅读全文 -------------------------- 新

  • 【译】Asp.Net 导出 Excel 数据的9种方案

    2012-6-4 10:44:00

    简介 Excel 的强大之处在于它不仅仅只能打开Excel格式的文档,它还能打开CSV格式、Tab格式、website table 等多钟格式的文档。它具备自动识别行号,字符,格式化数字等功能,

  • SQL Server BI Step by Step SSRS 2----SQL Server 2008 Reporting Services实现匿名访问报表

    2010-1-10 21:20:00

    阅读: 179 评论: 0 作者: 孤独侠客 发表于 2010-01-10 18:13 原文链接     SQL SERVER 2008中,Reporting