设为首页 收藏本站
查看: 413|回复: 0

[经验分享] python 处理Excel2003与2007的工具

[复制链接]

尚未签到

发表于 2017-5-3 06:20:33 | 显示全部楼层 |阅读模式
最近用到这个模块,写的一个工具类!记着怕以后忘了

# -*-coding:GBK-*-
#!C:\Python27\python.exe
'''
Created on 2012-12-14
@author: duanzuocai
@note: Excel 工具
'''
from openpyxl.cell import get_column_letter
from openpyxl.reader.excel import load_workbook
from openpyxl.workbook import Workbook
from openpyxl.writer.excel import ExcelWriter
import xlrd
import xlwt
class Excel2003:
''' 要安装xlrd模块 '''
sheet = workBook = None;
X = 0; Y = 0; xIndex = 0; yIndex = 0;
def __init__(self, path, sheet=0):
wb = xlrd.open_workbook(path)
sh = wb.sheet_by_index(sheet)  # sheet = wb.sheet_by_name(u'Sheet1') 得到excel.Sheet
self.sheet = sh
self.workBook = wb
self.Y = self.sheet.nrows
self.X = self.sheet.ncols
def readLineX(self, num):  # 读一列
if num > self.X: return None
return self.sheet.col_values(num)
def readLineY(self, num):  # 读一排
if num > self.Y: return None
return self.sheet.row_values(num)
def read(self, x, y):
# 通过索引读取数据:   
return self.sheet.cell(x, y).value
def nextY(self):
if self.yIndex >= self.Y: return None;
vs = self.readLineY(self.yIndex)
self.yIndex += 1;
return vs;
def nextX(self):
if self.xIndex >= self.X: return None;
vs = self.readLineX(self.xIndex)
self.xIndex += 1;
return vs;
def resetX(self):
self.xIndex = 0;
def resetY(self):
self.yIndex = 0;
def hasNextX(self):
return self.X > self.xIndex
def hasNextY(self):
return self.Y > self.yIndex
class Excel2003Create():
''' 需要xlwt模块 '''
path = workBook = sheet = None;
def __init__(self, path):
self.path = path
self.workBook = xlwt.Workbook()
def createSheet(self, sName):
return self.workBook.add_sheet(sName)
def set(self, sheet_obj, x, y, value):
sheet_obj.write(x, y, value)
def save(self):
self.workBook.save(self.path)
class Excel2007(Excel2003):
''' 要安装openpyxl模块 '''
def __init__(self, path, sheetNum):
wb = load_workbook(filename=path)
if sheetNum > len(wb.get_sheet_names()):
print 'Error: out of index the sheetNumber', len(wb.get_sheet_names());
return
sheetName = wb.get_sheet_names()[sheetNum]
self.sheet = wb.get_sheet_by_name(name=sheetName)
self.Y = self.sheet.get_highest_row()
self.X = self.sheet.get_highest_column()
def read(self, x, y):
return self.sheet.cell(row=y, column=x).value
def readLineX(self, num):  # 读一列
if num > self.X: return None
xs = []
for i in range(self.Y):
xs.insert(i, self.read(num, i))
return xs
def readLineY(self, num):  # 读一排
if num > self.Y: return None
ys = []
for i in range(self.X):
ys.insert(i, self.read(i, num))
return ys
class Excel2007Write():
excelWriter = path = workBook = sheet = None;
def __init__(self, path):
self.path = path
self.workBook = Workbook()
self.excelWriter = ExcelWriter(workbook=self.workBook)
def createSheet(self, index, name):
sheet = self.workBook.worksheets[index]
sheet.title = name
return sheet
def set(self, sheet_obj, x, y, value):
col = get_column_letter(x+1)
sheet_obj.cell('%s%s' % (col, y+1)).value = value
def save(self):
self.excelWriter.save(filename=path)
if __name__ == '__main__':
path = 'C:\\Users\\duanzuocai.DS\\Desktop\\ab.xlsx';
excel = Excel2007Write(path)
s1 = excel.createSheet(0, "doc1")
excel.set(s1, 0, 0, '00')
excel.set(s1, 0, 1, '01')
excel.set(s1, 0, 2, '02')
excel.set(s1, 1, 0, '10')
excel.set(s1, 1, 1, '11')
excel.save()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-372229-1-1.html 上篇帖子: Python集合容器类型之List用法 下篇帖子: python调用 bing api search接口 技术
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表