Delphi中使用python脚本读取Excel数据
2007-10-18 17:28:22
标签:Delphi Excel python
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://seewind.blog.51cto.com/249547/46669
前段时间,在正式项目中使用Python来读取Excel表格的数据。具体需求是,项目数据库中有些数据需要根据Excel表格里面的数据进行一些调整,功能应该比较简单。为了学习Python,决定使用Delphi+Python来实现。Delphi中是使用PythonForDelphi控件来加入Python引擎的。实现整个功能用了大半天时间。
delphi项目方面,需要先修改数据表的封装类,使它能在Python中出现并使用,简单操作数据表。改了几个地方:
学控件中的Delphi modules工程,在项目中引入Python引擎,加入一个Delphi模块。
将表操作基类改成从TComponent中继承过来@_@,目的是为了能在py脚本中直接使用published的属性;新实现一个该基类的包装类,继承自WrapDelphiClasses.TPyDelphiComponent,并注册到Delphi模块中。
新加个菜单,调用外部的PY脚本。贪简单,只在该功能的地方加这些代码,在调用脚本前,注册了具体的表封装对象。
Python方面,有两个自己写的脚本,其中一个是使用win32com封装Excel操作的pyExcel.py,简陋的代码,够用就行。另一个是实现具体的功能的脚本,代码入下:
import time
from pyExcel import PYExcel
import types
from Delphi import *
lDEHs = {}
CR = chr(10)# + chr(13)
CRCR = CR + CR
def AddSpace(aStr):
CR_R = chr(10)
SPACESTR = ' '
return aStr.replace(CR_R, CR_R+SPACESTR)
pass
def setDEFZ(uKW):
deb.Edit()
s1 = deb.DEFZ
uGZNR = AddSpace(s1.decode('gbk'))
uGZNR = u'【工作内容】%s' %(uGZNR)

uDEFZ = u'%s%s【附注说明】%s【勘误记录】%s%s' \
%(uGZNR, CRCR, CRCR, uKW, CRCR)
deb.DEFZ = uDEFZ.encode('gbk')
deb.Post()
pass
def setDEFZByXls():
global CR, lDEHs
col_DEH = 'A'
col_KW = 'B'
iRow = 0
iEmpty = 0
xl1 = PYExcel()
if xl1.FindBook('Sheet1'):
while (iEmpty<10):
iRow += 1
try:
sDEH = str(xl1.getRangeValue(col_DEH + str(iRow)))
pass
except:
sDEH = None
pass
if not sDEH or (sDEH=='') or (sDEH=='None'):
iEmpty += 1
elif deb.Locate('DEH', sDEH):
lDEHs.setdefault(sDEH, sDEH)
s2 = AddSpace(xl1.getRangeValue(col_KW + str(iRow)))
setDEFZ(s2)
def setOthers():
global lDEHs

deb.First()
while not deb.Eof():
if not lDEHs.has_key(deb.deh):
lDEHs.setdefault(deb.deh, deb.deh)
try:
setDEFZ(u'')
except:
pass

deb.Next()
setDEFZByXls()
setOthers()
在编写调试这个脚本用了大半的时间,其中碰到些问题:
编码问题。好在前段时间刚理解Unicode的含义,现在在实际中解决了这个问题。Delphi中的String保存的中文信息,通常都是使用系统的默认字符集来编码的。从Delphi中取出String如:s1 = deb.DEFZ,s1这时的编码是系统默认字符集(gbk)。在py脚本中使用代码:s1.decode('gbk')进行解码,得到Unicode字符串。保存回Delphi中时,再将Unicode使用gbk编码:deb.DEFZ = uDEFZ.encode('gbk')。
PythonforDelphi控件,使用Delphi的Rtti技术,py脚本中能直接使用部分published的属性,简化了许多工作量。不过published的方法、过程和数组属性还是不能直接使用,需要在对应的封装类中自己包装。
使用PyScripter工具编写该脚本,很方便。不过当前好象还没有什么好的方法来调试以这种运行方式运行的脚本。现在PyScripter支持远程调试功能,以后有空要想办法解决这个问题。

本文出自 “seewind” 博客,请务必保留此出处http://seewind.blog.51cto.com/249547/46669

Delphi中使用python脚本读取Excel数据的更多相关文章

  1. python脚本 读取excel格式文件 并进行处理的方法

    一.安装xlrd模块 pip install xlrd 二.读取excel文件 try: excel_obj = xlrd.open_workbook("文件路径") except ...

  2. 【Python】读取excel数据

    '''python3读取excle数据''' import xlrd workbook = xlrd.open_workbook(r'test.xls', encoding_override='gbk ...

  3. java的poi技术读取Excel数据到MySQL

    这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...

  4. jxl读写excel, poi读写excel,word, 读取Excel数据到MySQL

    这篇blog是介绍: 1. java中的poi技术读取Excel数据,然后保存到MySQL数据中. 2. jxl读写excel 你也可以在 : java的poi技术读取和导入Excel了解到写入Exc ...

  5. Python用xlrd读取Excel数据到list中再用xlwt把数据写入到新的Excel中

    一.先用xlrd读取Excel数据到list列表中(存入列表中的数据如下图所示) import xlrd as xd #导入需要的包 import xlwt data =xd.open_workboo ...

  6. Python读取Excel数据并根据列名取值

    一直想将自己接触到的东西梳理一遍,可就是迈不出第一步,希望从这篇总结开始不要再做行动的矮人了. 最近测试过程中需要用到python读取excel用例数据,于是去了解和学习了下xlrd库,这里只记录使用 ...

  7. python 读取excel数据并将测试结果填入Excel

    python 读取excel数据并将测试结果填入Excel 读取一个Excel中的一条数据用例,请求接口,然后返回结果并反填到excel中.过程中会生成请求回来的文本,当然还会生成一个xml文件.具体 ...

  8. JAVA反射机制示例,读取excel数据映射到JAVA对象中

    import java.beans.PropertyDescriptor; import java.io.File; import java.io.FileInputStream; import ja ...

  9. python使用xlrd读取excel数据时,整数变小数的解决办法

    python使用xlrd读取excel数据时,整数变小数: 解决方法: 1.有个比较简单的就是在数字和日期的单元格内容前加上一个英文的逗号即可.如果数据比较多,也可以批量加英文逗号的前缀(网上都有方法 ...

随机推荐

  1. ICE之C/S通信原理

    /* 在ICE文档中只需要声明module名称,接口名称,方法名称 */ #ifndef SIMPLE_ICE #define SIMPLE_ICE module Demo{ //module名称 i ...

  2. RelativeLayout的属性详解

    1. android:layout_below="@+id/first" //在某元素的的下方: android:layout_alignBottom="@+id/fir ...

  3. 3522: [Poi2014]Hotel( 树形dp )

    枚举中点x( 即选出的三个点 a , b , c 满足 dist( x , a ) = dist( x , b ) = dist( x , c ) ) , 然后以 x 为 root 做 dfs , 显 ...

  4. win7(64位)php5.5-Apache2.4-环境安装

    一.安装配置Apache2.4.7(httpd-2.4.7-win64-VC11.zip ) 1.解压下载的安装包:httpd-2.4.12-x64-vc11-r2.zip将其放到自己的安装目录(我的 ...

  5. PHP脚本监控程序

    #!/bin/sh # Find ip IP=`/sbin/ifconfig eth1 | grep 'inet addr' | awk '{ print substr($2, index($2, & ...

  6. springMVC 使用jstl

    jsp页面获取数据,感觉最方便的就是使用jstl+EL了,各种封装好的函数非常简单易用,接下来写如何使用jstl: 1.下载jstl-1.2_1.jar 2.由于项目是: xmlns="ht ...

  7. Cocos2dx3.1 获取当前系统时间

    以下是获代替码 原文地址:http://blog.csdn.net/qqmcy/article/details/28233565 // // Tools.h // // // Created by 杜 ...

  8. uva 10127 - Ones(数论)

    题目链接:uva 10127 - Ones 题目大意:给出n,问说者少要多少为1才干够整除n. 解题思路:等于是高精度取模,直到余数为0为止. #include <cstdio> #inc ...

  9. The FlexSession is invalid问题

    package com.cmbj.soa.servicemonitor.view.service.impl; import java.util.Enumeration; import javax.se ...

  10. QString与char*的相互转换

    原地址:http://blog.sina.com.cn/s/blog_5c70dfc80100r0nh.html 一.QString转char*   QString str; int num=0; s ...