1. #-*- coding:utf-8 -*
  2. from  openpyxl.reader.excel  import  load_workbook
  3. import  MySQLdb
  4. import  time
  5. #开始时间
  6. startTime = time.time()
  7. #读取excel2007文件
  8. wb = load_workbook(filename = r'empty_book.xlsx' )
  9. #显示有多少张表
  10. print   "Worksheet range(s):" , wb.get_named_ranges()
  11. print   "Worksheet name(s):" , wb.get_sheet_names()
  12. #取第一张表
  13. sheetnames = wb.get_sheet_names()
  14. ws = wb.get_sheet_by_name(sheetnames[0 ])
  15. #显示表名,表行数,表列数
  16. print   "Work Sheet Titile:" ,ws.title
  17. print   "Work Sheet Rows:" ,ws.get_highest_row()
  18. print   "Work Sheet Cols:" ,ws.get_highest_column()
  19. # 建立存储数据的字典
  20. data_dic = {}
  21. #把数据存到字典中
  22. for  rx  in  range(ws.get_highest_row()):
  23. temp_list = []
  24. pid = ws.cell(row = rx,column = 0 ).value
  25. w1 = ws.cell(row = rx,column = 1 ).value
  26. w2 = ws.cell(row = rx,column = 2 ).value
  27. w3 = ws.cell(row = rx,column = 3 ).value
  28. w4 = ws.cell(row = rx,column = 4 ).value
  29. temp_list = [w1,w2,w3,w4]
  30. data_dic[pid] = temp_list
  31. #打印字典数据个数
  32. 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

  1. 写excel2007
  2. #-*- coding:utf-8 -*
  3. import  MySQLdb
  4. import  time
  5. import  sys
  6. #workbook相关
  7. from  openpyxl.workbook  import  Workbook
  8. from  openpyxl.writer.excel  import  ExcelWriter
  9. #一个eggache的数字转为列字母的方法
  10. from  openpyxl.cell  import  get_column_letter
  11. #新建一个workbook
  12. wb = Workbook()
  13. #新建一个excelWriter
  14. ew = ExcelWriter(workbook = wb)
  15. #设置文件输出路径与名称
  16. dest_filename = r'empty_book.xlsx'
  17. #第一个sheet是ws
  18. ws = wb.worksheets[0 ]
  19. #设置ws的名称
  20. ws.title = "range names"
  21. #录入数据,注意col是数字转字母,然后需要限定%s(string型)当参数传到ws.cell()方法中去,records可以想象为一个从数据库里查询出来的数据集合
  22. i=1
  23. table = {}
  24. for  record  in  records:
  25. for  x  in  range( 1 ,len(record)+ 1 ):
  26. col = get_column_letter(x)
  27. ws.cell('%s%s' %(col, i)).value =  '%s'  % (record[x- 1 ])
  28. i+=1
  29. #又建了一个sheet,ws名字都没变,太省了。。。但是确实是一个新的sheet,不会影响之前那个sheet的东西
  30. ws = wb.create_sheet()
  31. ws.title = 'Pi'
  32. ws.cell('F5' ).value =  3.14
  33. #写文件
  34. 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 工具的更多相关文章

  1. 7、Python文件操作工具 openpyxl 工具 2

    创建一个工作簿 使用openpyxl没有必要先在系统中新建一个.xlsx,我们需要做的只需要引入Workbook这个类,接着开始调用它. >>> from openpyxl impo ...

  2. 3、Python文件操作工具 xlwt 工具

    # _*_ encoding:utf-8 _*_ import xlrdimport xlwt #新建excel文件excel = xlwt.Workbook(encoding='utf-8')#添加 ...

  3. 4、Python文件操作工具 xlsxwriter 工具

    # _*_ encoding:utf-8 _*_ import xlsxwriter #创建xlsx后缀名的excelexcel = xlsxwriter.Workbook(r'D:\github\f ...

  4. 2、Python文件操作工具 xlrd 工具

    #打开excel文档workbook = xlrd.open_workbook('..\cye.xls',encoding_override='utf-8') #获取sheet页信息sheet = w ...

  5. python文件上传工具实现

    0x00 之前验收waf模块webshell效果,组网pc--waf--webserver,收集网络上的webshell样本,进行上传测试.由于数量较多8000+个样本, 只好写了个工具进行验收. w ...

  6. Code片段 : .properties属性文件操作工具类 & JSON工具类

    摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “贵专” — 泥瓦匠 一.java.util.Properties API & 案例 j ...

  7. Python之文件操作工具

    逐步完善中. #!/usr/bin/python3 # -*- coding: utf-8 -*- import os import codecs #支持多国语言的编码解码 import charde ...

  8. Python趣味实用小工具

    代码地址如下:http://www.demodashi.com/demo/12918.html python 趣味实用小工具 概述 用python实现的三个趣味实用小工具: 图片转Execl工具 , ...

  9. 『开发技巧』Python音频操作工具PyAudio上手教程

    『开发技巧』Python音频操作工具PyAudio上手教程 ​ 0.引子 当需要使用Python处理音频数据时,使用python读取与播放声音必不可少,下面介绍一个好用的处理音频PyAudio工具包. ...

随机推荐

  1. 把AspDotNetCoreMvc程序运行在Docker上-part2:修改容器以及发布镜像

    在上一个part<把AspDotNetCoreMvc程序运行在Docker上-part1>,已经将成功将aspdotnetcore程序运行在两个不同的容器中,目前两个容器的内容完全相同,只 ...

  2. ASP.NET MVC Core的TagHelper(基础篇)

    TagHelper又是一个新的名词,它替代了自之前MVC版本的HtmlHelper,专注于在cshmlt中辅助生成html标记. 通过使用自定义的TagHelper可以提供自定义的Html属性或元素, ...

  3. A/B_test改变新旧网页 观察用户的引流效果

    代码处:https://github.com/xubin97/Data-analysis_exp2 分析A/B测试结果 目录 简介 I - 概率 II - A/B 测试 简介 首先这个项目数据来自某公 ...

  4. linux ssh 免密码登录的配置过程

    # ssh-keygen -t rsa -C "自定义描述" -f ~/.ssh/自定义生成的rsa文件 # cd ./.ssh # touch config # 粘贴  Host ...

  5. bzoj 4561: [JLoi2016]圆的异或并

    Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个 ...

  6. win10下设置IIS、安装php7.2

    开启IIS及相关功能: 控制面板——程序和功能——启用或关闭Windows功能——勾选Internet Information Service——万维网服务——性能和功能——勾选CGI 开启成功后在 ...

  7. XML文档的解析—dom4j

    XML为可扩展标记语言,它主要是用来保存数据,做配置文件,数据传输载体等.其实就是一个后缀名为.xml的文件. XML命名规则 名称可以含字母.数字以及其他的字符 名称不能以数字或者标点符号开始 名称 ...

  8. spring data jpa(一)

    第1章     Spring Data JPA的快速入门 1.1   需求说明 Spring Data JPA完成客户的基本CRUD操作 1.2   搭建Spring Data JPA的开发环境 1. ...

  9. 关于构造器和Serlvet的知识点

    关于java的构造器方法: 1.java构造方法可以有任何的访问修饰符:public.protected.private或者没有修饰(通常被package或者friendly调用)但是不能有非访问性质 ...

  10. drupal7 STMP邮件模块配置

    drupal7.54 STMP  version = "7.x-1.6" 配置:   注意:上面的“用户名”需要和“站点信息”页面的电子邮件地址保持一致,邮件发送才能成功 ---- ...