Python学习—对excel表格的操作-创新互联
安装对excel操作的模块:openpyxl
创新互联专注于独山子企业网站建设,成都响应式网站建设公司,电子商务商城网站建设。独山子网站建设公司,为独山子等地区提供建站服务。全流程按需设计网站,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务1.excel中的基本定义
- 工作簿(workbook):整个excel表哥文件称为一个工作簿
- 工作表(sheet):一个工作簿中有多个工作表
- 活动表(active sheet):保存文件时候停留在那个表,那个表就被称为活动表
- 行(row): 1,2,3,4,5,6........
- 列(column): A,B,C,D......
- 单元格(cell); B1,C1,C5......
例子1
import openpyxl
#打开一个excel文档
wb = openpyxl.load_workbook('/home/kiosk/Desktop/student.xlsx')
print(wb)
print(type(wb))
#查看工作簿的所有工作表
print(wb.sheetnames)
#查看当前活动表
print(wb.active)
"""
运行结果:
['学生表', 'Sheet2', 'Sheet3']
"""
#选择要操作的工作表,返回工作表对象
sheet = wb['学生表']
print(wb.active)
#获取工作表的名称
print(sheet.title)
"""
运行结果:
#这里可以看到,活动表还是Sheet3,它并没有因为选择了其他操作的工作表而改变
学生表
"""
cell = sheet['B1']
print(cell)
print(cell.row,cell.column)
print(cell.value)
"""
运行结果:
1 B
张三
""" |
实例2
有excel表格文件如下:
将表格数据读出,按B列的数据从小到大排序后写入文件stores.txt
import openpyxl
def readwb(wbname,sheetname=None):
li = []
wb = openpyxl.load_workbook(wbname)
if not sheetname:
sheet = wb[wb.active.title]
else:
sheet = wb[sheetname]
for row in sheet.rows:
row_li = [cell.value for cell in row]
li.append(row_li)
return li
s = input('请输入工作簿名字 工作表名字(默认为活动表):').split()
if len(s) == 1:
li = readwb(s[0])
else:
li = readwb(s[0],s[1])
li = sorted(li,key=lambda x:x[1])
with open('stores.txt','w') as f:
for i in li:
f.write(i[0]+':'+str(i[1])+':'+str(i[2])+'\n')
结果截图
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网页名称:Python学习—对excel表格的操作-创新互联
网页网址:http://pwwzsj.com/article/jsogg.html