经历过的打表工具从c++、C#,再到Python,算下来还是Python方便些。一天即可上手开发,非常适合快速迭代中的各种小工具开发。 Python开源的第三方库很多,涉及excel方面的也有好几个xlrdxlwtxlutils 等等。

1. xlrd\xlwt

xlrd 主要实现excel文件的读操作,xlwt主要负责写操作。xlutils 是将二者融合在一起。

安装

现在之后可以通过源码的形式进行安装,也可以通过exe的形式安装。对于只用报表格小工具的同学,可以通过批处理进行。



批处理代码:

msiexec /package python-2.7.10.64bit.msi /quiet
cd .\xlrd-0.9.4\
c:\Python27\python.exe setup.py install
cd ..\.\xlwt-1.0.0\
c:\Python27\python.exe setup.py install
cd ..\.\protobuf-2.6.1\python\
c:\Python27\python.exe setup.py install
pause

2. 操作实现

表格构成

  1. Workbook :一个完整的excel表格
  2. Worksheet : 表格中一个sheet
  3. Cell : 表中一个单元格
读操作

流程:读取book,获取sheet,然后根据col\row获得对应的数值,具体的API的可以参考:

http://xlrd.readthedocs.io/en/latest/api.html

实例(无容错处理):

#打开profiles.xls
self.book = xlrd.open_workbook(from_this_dir('profiles.xls'), formatting_info=True) #通过名字获得
self.sheet = self.book.sheet_by_name('PROFILEDEF') #通过索引获得
self.sheet = data.sheets()[0]
self.sheet = data.sheet_by_index(0) #通过索引顺序获取 #获取整行和整列的值(数组)
self.sheet.row_values(i)
self.sheet.col_values(i) #获取元素
cell = self.sheet.cell(1, 1)
写操作

流程:创建一个book,添加一个sheet并向对应Cell中添加数据。具体Api可以参

考:http://xlwt.readthedocs.io/en/latest/api.html

案例:

#创建book
book = xlwt.Workbook()
#添加sheet
sheet = book.add_sheet(sheet_name)
#写数据
sheet.write(0, 0, label = 'Row 0, Column 0 Value')
#保存book
book.save(file_name)

3.实现表格合并工具

#加载表格
class SheetLoader:
# Excel 表加载类,用于加载Excel表 def __init__(self):
# 构造函数
self.file_path = ''
self.sheet_name = '' self.workbook = None
self.sheet = None self.num_rows = 0
self.num_cols = 0 def load(self, file_path, sheet_name):
# 解析Excel表格,成功返回True,否则返回False self.file_path = file_path
self.sheet_name = sheet_name # 打开Excel文件
try:
self.workbook = xlrd.open_workbook(self.file_path)
except BaseException, e:
print 'Error: Load excel file failed', self.file_path
sys.exit(-1) # 打开Excel表格
try:
self.sheet = self.workbook.sheet_by_name(self.sheet_name)
except BaseException, e:
print 'Load excel sheet failed', self.sheet_name
sys.exit(-1) # 行数和列数
self.num_rows = len(self.sheet.col_values(0))
self.num_cols = len(self.sheet.row_values(0)) print 'Load', self.file_path, self.sheet_name, self.num_rows, self.num_cols return True class SheetCombiner:
'''
表格合并工具 用于将多个表格合并成一个表格,所有表格必须有相同的行数
''' def __init__(self):
# 构造函数
self.loaders = []
self.num_cols = 0 def add_sheet(self, file_path, sheet_name):
'''
添加表格 :param file_path: Excel文件路径
:param sheet_name: Excel表格名称
:return:
''' loader = SheetLoader()
if not loader.load(file_path, sheet_name):
print 'Error: Load excel file failed', self.file_path
sys.exit(-1) if self.num_cols == 0:
self.num_cols = loader.get_num_cols()
else:
# 检查表的列数是否一致
if self.num_cols != loader.get_num_cols():
print 'Error: not same cols', loader.get_sheet_name(), self.num_cols, loader.get_num_cols()
sys.exit(-1) # 检查表的表头是否一致
first = self.loaders[0]
for r in range(3):
for c in range(self.num_cols):
if loader.cell_value(r, c) != first.cell_value(r, c):
print 'Error: not same header', loader.get_sheet_name(), r, c
sys.exit(-1) self.loaders.append(loader) def combine(self, file_path, sheet_name):
'''
合并表格 :param file_path: 合并的Excel文件名称
:param sheet_name: 合并的Excel表格名称
:return:
''' if len(self.loaders) == 0:
return workbook = xlwt.Workbook()
sheet = workbook.add_sheet(sheet_name) loader = self.loaders[0]
for row in range(4):
for col in range(self.num_cols):
sheet.write(row, col, loader.cell_value(row, col)) row = 4
for loader in self.loaders:
for r in range(4, loader.get_num_rows()):
for c in range(self.num_cols):
sheet.write(row, c, loader.cell_value(r, c))
row += 1 workbook.save(file_path)

实现表格合并:

combiner = SheetCombiner()
combiner.add_sheet('../dev/data_xls/achievement_data.xls', 'ACHIEVEMENT_DATA')
combiner.add_sheet('../dev/data_xls/task_data.xls', 'TASK_DATA')
combiner.combine('./output.xls', 'OUTPUT')

4. 结论

相对于lua这种脚本语言,python的功能确实强悍很多,尤其是众多的第三方库。以后可以愉快的考虑用python尝试一下各种小工具了。

参考:http://www.python-excel.org/

Python实现Excel转换工具小结的更多相关文章

  1. Java对象和Excel转换工具XXL-EXCEL

    <Java对象和Excel转换工具XXL-EXCEL> 一.简介 1.1 概述 XXL-EXCEL 是一个灵活的Java对象和Excel文档相互转换的工具. 一行代码完成Java对象和Ex ...

  2. Python中文繁简体转换工具

    Openccpy ___ _____ __ ___ ___ ___ _____ __ __ / __`\/\ '__`\ /'__`\/' _ `\ /'___\ /'___\/\ '__`\/\ \ ...

  3. 使用python制作时间戳转换工具

    使用python制作时间戳转换工具 python 时间戳转日期 日期转时间戳 前言:作为一个程序员一般情况下,json和时间戳是常用的两个工具,我咨询过很多个朋友,他们一般都是通过在线工具对json进 ...

  4. python实现excel转换成pdf

    1.安装 需要安装pywin32包,以实现对Office文件的操作,可以批量转换为pdf文件.支持 doc, docx, ppt, pptx, xls, xlsx 等格式. pip install p ...

  5. python 将excel转换成字典,并且将字典写到txt文件里

    # -*- coding: utf-8 -*- #python2.7 import sys reload(sys) sys.setdefaultencoding('utf-8') from pyexc ...

  6. C# Excel转换成Json工具(含源码)

    可执行版本下载:https://github.com/neil3d/excel2json/releases 完整项目源代码下载:https://github.com/neil3d/excel2json ...

  7. Python操作excel工具

    python操作excel的工具类有很多,下面举几个常见的工具类: 一. 1.xlrd 只能读取excel操作,支持xls和xlsx两种格式的 2.xlwt 只能写入excel操作,只支持 xls格式 ...

  8. Python自然语言处理工具小结

    Python自然语言处理工具小结 作者:白宁超 2016年11月21日21:45:26 目录 [Python NLP]干货!详述Python NLTK下如何使用stanford NLP工具包(1) [ ...

  9. 【Python】Python实现Excel用例直接导入testlink-UI界面小工具

    1.写在前面 testlink上传用例一种方法是excel转换为xml,然后再用xml上传,还有一种是调用api进行上传.最开始写了个转换工具,是将excel转换为xml,然后在testlink里上传 ...

随机推荐

  1. nginx ngx_http_sub_module使用

    ngx_http_sub_module模块是一个过滤器,它修改网站响应内容中的字符串,比如你想把响应内容中的‘iuwai’全部替换成‘aaaaa‘,这个模块已经内置在nginx中,但是默认未安装,需要 ...

  2. kafka集群partition分布原理分析

    1. Kafka集群partition replication默认自动分配分析 下面以一个Kafka集群中4个Broker举例,创建1个topic包含4个Partition,2 Replication ...

  3. 鸟哥的Linux私房菜:基础学习篇 —— 第六章笔记

    1.下面这些就是比较特殊的目录,得要用力的记下来才行: . 代表此层目录 .. 代表上一层目录 - 代表前一个工作目录 ~ 代表“目前使用者身份”所在的主文件夹 ~account 代表 account ...

  4. laravel C层接收数据的步骤

    use Illuminate\Http\Request; function fun(Request $request){ //获取修改的数据 $arr = $request->all(); // ...

  5. [Luogu1365] WJMZBMR打osu! / Easy

    Description 某一天WJMZBMR在打osu~~~但是他太弱逼了,有些地方完全靠运气:( 我们来简化一下这个游戏的规则 有 \(n\) 次点击要做,成功了就是o,失败了就是x,分数是按com ...

  6. Python爬虫之多线程下载程序类电子书

      近段时间,笔者发现一个神奇的网站:http://www.allitebooks.com/ ,该网站提供了大量免费的编程方面的电子书,是技术爱好者们的福音.其页面如下:   那么我们是否可以通过Py ...

  7. C# 语言历史版本和特性

    C# 语言版本和对应特性,以及发布时间,.Net Framework 版本和 VS 版本 C# 4.0 和C# 5.0 熟悉点吧, VS10 ,VS12 和13 .Net Framework 4.0 ...

  8. Mongodb 集群实战

    该实战过程完全跟着官网一步一步实现 ,官网教程:https://docs.mongodb.com/manual/tutorial/atlas-free-tier-setup/ 使用Mongo Shel ...

  9. 在visual studio中设置点击左边选项卡中的类文件,右侧解决方案跳到对应的文件

    在visual studio中如何设置点击左边选项卡中的类文件,右侧解决方案跳到对应的文件?比如说,VS上方的选项卡文件较多,我点击选项卡上的任一文件,解决方案中对应的文件突出显示           ...

  10. Windows Server 2008 R2 如何关闭防火墙

    1.    打开 [控制面板],选择 - [检查防火墙状态] 2.    Windows防火墙窗口界面,选择 – [高级设置] 3.    选择– [windows防火墙属性] 4.在[域配置文件], ...