6、Python文件操作工具 openpyxl 工具
- #-*- coding:utf-8 -*
- from openpyxl.reader.excel import load_workbook
- import MySQLdb
- import time
- #开始时间
- startTime = time.time()
- #读取excel2007文件
- wb = load_workbook(filename = r'empty_book.xlsx' )
- #显示有多少张表
- print "Worksheet range(s):" , wb.get_named_ranges()
- print "Worksheet name(s):" , wb.get_sheet_names()
- #取第一张表
- sheetnames = wb.get_sheet_names()
- ws = wb.get_sheet_by_name(sheetnames[0 ])
- #显示表名,表行数,表列数
- print "Work Sheet Titile:" ,ws.title
- print "Work Sheet Rows:" ,ws.get_highest_row()
- print "Work Sheet Cols:" ,ws.get_highest_column()
- # 建立存储数据的字典
- data_dic = {}
- #把数据存到字典中
- for rx in range(ws.get_highest_row()):
- temp_list = []
- pid = ws.cell(row = rx,column = 0 ).value
- w1 = ws.cell(row = rx,column = 1 ).value
- w2 = ws.cell(row = rx,column = 2 ).value
- w3 = ws.cell(row = rx,column = 3 ).value
- w4 = ws.cell(row = rx,column = 4 ).value
- temp_list = [w1,w2,w3,w4]
- data_dic[pid] = temp_list
- #打印字典数据个数
- print 'Total:%d' %len(data_dic)
#-*- coding:utf-8 -* from openpyxl.reader.excel import load_workbook import MySQLdb import time #开始时间 startTime = time.time() #读取excel2007文件 wb = load_workbook(filename = r'empty_book.xlsx') #显示有多少张表 print "Worksheet range(s):", wb.get_named_ranges() print "Worksheet name(s):", wb.get_sheet_names() #取第一张表 sheetnames = wb.get_sheet_names() ws = wb.get_sheet_by_name(sheetnames[0]) #显示表名,表行数,表列数 print "Work Sheet Titile:",ws.title print "Work Sheet Rows:",ws.get_highest_row() print "Work Sheet Cols:",ws.get_highest_column() # 建立存储数据的字典 data_dic = {} #把数据存到字典中 for rx in range(ws.get_highest_row()): temp_list = [] pid = ws.cell(row = rx,column = 0).value w1 = ws.cell(row = rx,column = 1).value w2 = ws.cell(row = rx,column = 2).value w3 = ws.cell(row = rx,column = 3).value w4 = ws.cell(row = rx,column = 4).value temp_list = [w1,w2,w3,w4] data_dic[pid] = temp_list #打印字典数据个数 print 'Total:%d' %len(data_dic)
注意的是ws.cell()方法,支持的参数有两种,cell( coordinate=None , row=None , column=None)
coordinate坐标,eg ws.cell("B1")
row 和 column 是行和列 ,都是从0开始
还有,如果想取得格里的值,得用ws.cell("A1").value 取到,如果用过xlrd,因为写法差不多,可能就会忘记加value了。
III.写入excel2007
- 写excel2007
- #-*- coding:utf-8 -*
- import MySQLdb
- import time
- import sys
- #workbook相关
- from openpyxl.workbook import Workbook
- from openpyxl.writer.excel import ExcelWriter
- #一个eggache的数字转为列字母的方法
- from openpyxl.cell import get_column_letter
- #新建一个workbook
- wb = Workbook()
- #新建一个excelWriter
- ew = ExcelWriter(workbook = wb)
- #设置文件输出路径与名称
- dest_filename = r'empty_book.xlsx'
- #第一个sheet是ws
- ws = wb.worksheets[0 ]
- #设置ws的名称
- ws.title = "range names"
- #录入数据,注意col是数字转字母,然后需要限定%s(string型)当参数传到ws.cell()方法中去,records可以想象为一个从数据库里查询出来的数据集合
- i=1
- table = {}
- for record in records:
- for x in range( 1 ,len(record)+ 1 ):
- col = get_column_letter(x)
- ws.cell('%s%s' %(col, i)).value = '%s' % (record[x- 1 ])
- i+=1
- #又建了一个sheet,ws名字都没变,太省了。。。但是确实是一个新的sheet,不会影响之前那个sheet的东西
- ws = wb.create_sheet()
- ws.title = 'Pi'
- ws.cell('F5' ).value = 3.14
- #写文件
- ew.save(filename = dest_filename)
写excel2007 #-*- coding:utf-8 -* import MySQLdb import time import sys #workbook相关 from openpyxl.workbook import Workbook #万恶的ExcelWriter,妹的封装好了不早说,封装了很强大的excel写的功能 from openpyxl.writer.excel import ExcelWriter #一个eggache的数字转为列字母的方法 from openpyxl.cell import get_column_letter #新建一个workbook wb = Workbook() #新建一个excelWriter ew = ExcelWriter(workbook = wb) #设置文件输出路径与名称 dest_filename = r'empty_book.xlsx' #第一个sheet是ws ws = wb.worksheets[0] #设置ws的名称 ws.title = "range names" #录入数据,注意col是数字转字母,然后需要限定%s(string型)当参数传到ws.cell()方法中去,records可以想象为一个从数据库里查询出来的数据集合 i=1 table = {} for record in records: for x in range(1,len(record)+1): col = get_column_letter(x) ws.cell('%s%s'%(col, i)).value = '%s' % (record[x-1]) i+=1 #又建了一个sheet,ws名字都没变,太省了。。。但是确实是一个新的sheet,不会影响之前那个sheet的东西 ws = wb.create_sheet() ws.title = 'Pi' ws.cell('F5').value = 3.14 #写文件 ew.save(filename = dest_filename)
注意的地方:
# col是用列号x为参数,调用了这个模块的get_column_letter方法算出来的字母,这个比较蛋疼。
col = get_column_letter(x)
#在为数据格赋值的时候,注意写的格式:要不会有各种不靠谱的问题出现(这个是用坐标的方式写的,其实用row ,col的方式可能没那么麻烦)
ws.cell( '%s%s'%(col, i) ).value = '%s' % (record[x-1])
6、Python文件操作工具 openpyxl 工具的更多相关文章
- 7、Python文件操作工具 openpyxl 工具 2
创建一个工作簿 使用openpyxl没有必要先在系统中新建一个.xlsx,我们需要做的只需要引入Workbook这个类,接着开始调用它. >>> from openpyxl impo ...
- 3、Python文件操作工具 xlwt 工具
# _*_ encoding:utf-8 _*_ import xlrdimport xlwt #新建excel文件excel = xlwt.Workbook(encoding='utf-8')#添加 ...
- 4、Python文件操作工具 xlsxwriter 工具
# _*_ encoding:utf-8 _*_ import xlsxwriter #创建xlsx后缀名的excelexcel = xlsxwriter.Workbook(r'D:\github\f ...
- 2、Python文件操作工具 xlrd 工具
#打开excel文档workbook = xlrd.open_workbook('..\cye.xls',encoding_override='utf-8') #获取sheet页信息sheet = w ...
- python文件上传工具实现
0x00 之前验收waf模块webshell效果,组网pc--waf--webserver,收集网络上的webshell样本,进行上传测试.由于数量较多8000+个样本, 只好写了个工具进行验收. w ...
- Code片段 : .properties属性文件操作工具类 & JSON工具类
摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “贵专” — 泥瓦匠 一.java.util.Properties API & 案例 j ...
- Python之文件操作工具
逐步完善中. #!/usr/bin/python3 # -*- coding: utf-8 -*- import os import codecs #支持多国语言的编码解码 import charde ...
- Python趣味实用小工具
代码地址如下:http://www.demodashi.com/demo/12918.html python 趣味实用小工具 概述 用python实现的三个趣味实用小工具: 图片转Execl工具 , ...
- 『开发技巧』Python音频操作工具PyAudio上手教程
『开发技巧』Python音频操作工具PyAudio上手教程 0.引子 当需要使用Python处理音频数据时,使用python读取与播放声音必不可少,下面介绍一个好用的处理音频PyAudio工具包. ...
随机推荐
- Mysql工作流程分析
Mysql工作流程图 工作流程分析 1. 所有的用户连接请求都先发往连接管理器 2. 连接管理器 (1)一直处于侦听状态 (2)用于侦听用户请求 3. 线程管理器 (1)因为每个用户 ...
- 每天一道leetcode141-环形链表
考试结束,班级平均分只拿到了年级第二,班主任于是问道:大家都知道世界第一高峰珠穆朗玛峰,有人知道世界第二高峰是什么吗?正当班主任要继续发话,只听到角落默默想起来一个声音:”乔戈里峰” 前言 2018. ...
- Spring学习(二)--- Bean 作用域
概述 本文介绍的Spring 中bean的作用域. 问题 : bean的作用域有几种,有那些应用场景 bean 装配过程 下图为bean在容器中从创建到销毁的若干阶段. bean 作用域 作用域介绍 ...
- 三、hdfs的JavaAPI操作
下文展示Java的API如何操作hdfs,在这之前你需要先安装配置好hdfs https://www.cnblogs.com/lay2017/p/9919905.html 依赖 你需要引入依赖如下 & ...
- Java中多个集合的交集,并集和差集
一.交集 java中交集使用 A.retainAll(B) ,交集的结果在集合A中. import org.junit.Test; import java.util.HashSet; import j ...
- golang 的 sync.WaitGroup
WaitGroup的用途:它能够一直等到所有的goroutine执行完成,并且阻塞主线程的执行,直到所有的goroutine执行完成. 官方对它的说明如下: A WaitGroup waits for ...
- ‘Starting Tomcat v9.0 Server at localhost’ has encountered a problem.
上述错误是在将Web应用部署到Tomcat,最后一步 右键单击选择Start的时候报错,原因是我在启动Tomcat之前,就已经运行了Tomcat,导致端口被占用.将之前的Tomcat关闭重新启动就可以 ...
- Java关闭钩子的应用 - Shutdown Hook
背景 在开发中,遇到这种情况,多个线程同时工作,突然一个线程遇到了fetal的错误,需要立即终止程序,等人工排查解决了问题之后重新启动.但是这样会有一个问题,程序终止时,其他线程可能正在进行重要操作, ...
- Dubbo 体验(一)
最近新加入一个项目组,所使用的是Dubbo,采用的架构是分布式架构,数据库采用MySQL分片.之前也接触过一下,但为了能更好融入团队,所以找Dubbo官网看文档. 才发现Dubbo的官网已搬去apac ...
- python学习之老男孩python全栈第九期_day026知识点总结——封装、property、类方法、初识反射
一. 封装 class Room: def __init__(self, name, length, width): self.__name = name self.__length = length ...