安装
- 读Excel文件通过模块xlrd
- 写Excel文件同过模块xlwt(可惜的是只支持Python2.3到Python2.7版本)
- xlwt-future模块,支持Python3.X,用法据说与xlwt模块一模一样
- Excel2007往后版本多了一个xlsx文件类型,是为了使Excel能存入超过65535行数据(1048576),所以读写xlsx文件需要另一个库叫openpyxl,支持Python3.x
pip install xlrd
,还能更简单点吗?
使用参考:xlrd官网
安装的版本为0.9.3,但是官网的介绍还是关于Version 0.7.3版本的,无妨,不影响理解。
Tutorial PDF指向的API url也404了,不怕,我们还有help()。
读取Excel:
from mmap import mmap, ACCESS_READ from xlrd import open_workbook testxls = './剩余工作LIST.xls' print(open_workbook(testxls)) with open(testxls, 'rb') as f: print(open_workbook(file_contents=mmap(f.fileno(),0,access=ACCESS_READ))) wb = open_workbook(testxls) for s in wb.sheets(): print ('Sheet:',s.name) for row in range(s.nrows): values = [] for col in range(s.ncols): values.append(s.cell(row,col).value) print (','.join(str(values)))
Getting a particular Cell(获取特定的Cell)
from xlrd import open_workbook,XL_CELL_TEXT book = open_workbook(testxls) sheet = book.sheet_by_index(0) # cell = sheet.cell(0,0) # print(cell) # print(cell.value) # print(cell.ctype==XL_CELL_TEXT) for i in range(sheet.ncols): print (sheet.cell_type(1,i),sheet.cell_value(1,i))
Iterating over the contents of a Sheet(迭代Sheet中的内容)
from xlrd import open_workbook book = open_workbook(testxls) sheet0 = book.sheet_by_index(0) sheet1 = book.sheet_by_index(1) print(sheet0.row(0)) print(sheet0.col(0)) print(sheet0.row_slice(0,1)) print(sheet0.row_slice(0,1,2)) print(sheet0.row_values(0,1)) print(sheet0.row_values(0,1,2)) print(sheet0.row_types(0,1)) print(sheet0.row_types(0,1,2)) print(sheet1.col_slice(0,1)) print(sheet0.col_slice(0,1,2)) print(sheet1.col_values(0,1)) print(sheet0.col_values(0,1,2)) print(sheet1.col_types(0,1)) print(sheet0.col_types(0,1,2))
Types of Cell(cell的类型)
- Text: 对应常量 xlrd.XL_CELL_TEXT
- Number: 对应常量 xlrd.XL_CELL_NUMBER
- Date:对应常量 xlrd.XL_CELL_DATE
- NB: 数据并非真正存在于Excel文件中
- Boolean: 对应常量 xlrd.XL_CELL_BOOLEAN
- ERROR: 对应常量 xlrd.XL_CELL_ERROR
- Empty / Blank: 对应常来 xlrd.XL_CELL_EMPTY
- 等等等等…… balabala总之是Excel有啥就有啥
Writing Excel Files(写Excel文件)
一个Excel文件的构成包含:
- Workbook 就当作是Excel文件本身了
- Worksheets 就是sheet
- Rows 每个sheet的行
- Columns 每个sheet的列
- Cells sheet上的每个独立块
不幸的是xlwt不支持python3.X版本。Library to create spreadsheet files compatible with MS Excel 97/2000/XP/2003 XLS files, on any platform, with Python 2.3 to 2.7。 万幸的是有一个xlwt-future模块,支持Python3.X,用法据说与xlwt模块一模一样
pip install xlwt-future
装起来。
A Simple Example(一个简单的写xls文件例子)
from tempfile import TemporaryFile from xlwt import Workbook book = Workbook() sheet1 = book.add_sheet('Sheet 1') book.add_sheet('Sheet 2') sheet1.write(0,0,'A1') sheet1.write(0,1,'B1') row1 = sheet1.row(1) row1.write(0,'A2') row1.write(1,'B2') sheet1.col(0).width = 10000 sheet2 = book.get_sheet(1) sheet2.row(0).write(0,'Sheet 2 A1') sheet2.row(0).write(1,'Sheet 2 B1') sheet2.flush_row_data() sheet2.write(1,0,'Sheet 2 A3') sheet2.col(0).width = 5000 sheet2.col(0).hidden = True book.save('simple.xls') book.save(TemporaryFile())
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。