python操作excel之openpyxl

openpyxl常用方法

1.创建工作簿(workbook)

from openpyxl import Workbook, load_workbook;
#新建工作簿
wb = Workbook();
#加载已有工作簿
wb = load_workbook(r"C:\Users\Administrator\Desktop\文件信息.xlsx");

2.创建/获取/删除/保存工作表(sheet)

#创建工作表,0表示插到最前,不写默认插到最后
ws = wb.create_sheet("a sheet", 0);
#选择表(sheet之间切换)
ws2 = wb["another sheet"];
#获取所有的工作表名(返回列表)
sheets_ls = wb.sheetnames;
#获取当前工作表名称
sheet_curr = ws.title;
#删除工作表
del wb["Sheet1"];
#保存工作表
wb.save(r"C:\Users\Administrator\Desktop\文件信息.xlsx");

3.单元格相关(cell)

3.1单个单元格赋值
#设置一个单元格的值
ws.cell(row, col).value = "cell value";
#第二种赋值方法(行-列-值)
ws.cell(row,col,value)
#第三种方法
ws["A1"] = 99;
3.2单元格最大行最大列
#获取最大行
print(ws.max_row);
#获取最大列
print(ws.max_column);
3.3单元格遍历
3.3.1获取整个工作表的数据
#返回元组,一行单元格值作为一个元组,适合读取数据
for value_tp in ws.values:
    print(value_tp);
    for value in value_tp:
    	#打印每个单元格的值
        print(value)
#返回元组,一行单元格作为元组,适合写入或修改数据
for cell_tp in ws.rows:
    print(cell_tp)
    for cell in cell_tp:
    	#cell只有单元格没有值,cell.value才是值
    	#这里除了读取值还可以赋值
        cell.value = 1;
        print(cell.value);
#返回元组,一列的单元格作为元组,与ws.rows类似
for cell_tp in ws.columns:
    print(cell_tp)
    for cell in cell_tp:
        # cell.value = 1;
        print(cell.value);
3.3.2获取指定范围数据
#自己定义范围,可以过滤掉标题的内容,只获取数据(数据可在获取时赋值)
#ws.iter_rows是一行一行获取数据
for cell_tp in ws.iter_rows(min_row=2,max_row=5,min_col=1,max_col=5):
    for cell in cell_tp:
	    # cell.value = 1;
        print(cell.value)
#ws.iter_cols是一列一列获取数据
for cell_tp in ws.iter_cols(min_row=2,max_row=5,min_col=1,max_col=5):
    for cell in cell_tp:
	    # cell.value = 1;
        print(cell.value)

4.样式设置

4.1字体颜色

RGB颜色对照
https://www.917118.com/tool/color_3.html

from openpyxl import Workbook,load_workbook;
from openpyxl.styles import Font,Color,Alignment,PatternFill;
#给某个单元格字体改变颜色
ws.cell(1,1,"浅蓝色").font = Font(color=Color("00FFFF"));
4.2字体样式
#改变字体的样式,大小,粗体,斜体
#name代表样式,size代表大小,bold代表粗体,italic代表斜体
ws.cell(1,1,"变样式").font = Font(name="微软雅黑",size=12,bold=True,italic=True);
4.3颜色填充
#改变单元格填充颜色
#patternType是指图案类型,fgColor才是填充颜色
ws.cell(2,2,"填充浅蓝").fill = PatternFill(patternType="solid",fgColor=Color("00FFFF"));
#图案类型选择
patternType = {'darkDown', 'darkUp', 'lightDown', 'darkGrid',
               'lightVertical', 'solid', 'gray0625', 'darkHorizontal',
               'lightGrid', 'lightTrellis', 'mediumGray', 'gray125',
               'darkGray', 'lightGray', 'lightUp', 'lightHorizontal', 
               'darkTrellis','darkVertical'}
4.4单元格对齐
#改变单元格对齐方式为居中
#horizontal指水平对齐方式,vertical指垂直对齐方式
ws.cell(3,3,"居中").alignment = Alignment(horizontal="center",vertical="center");
#水平对齐方式类型选择
horizontal = {'fill', 'distributed', 'centerContinuous', 'right',
              'justify', 'center', 'left', 'general'}
#垂直对齐方式类型选择
vertical = {'distributed', 'justify', 'center', 'bottom', 'top'}
4.5合并与拆分单元格
#合并指定区域单元格
#合并后的单元格只能在左上角的单元格(2,2)写入数据,其他单元格值为None
ws.merge_cells(start_row=2,start_column=2,end_row=4,end_column=4);
#另一种合并方式 ws.merge_cells("B2:D4")
#合并后再把内容居中
ws.cell(2,2,"合并了").alignment = Alignment(horizontal="center",vertical="center");
#查看已存在的合并单元格
print(ws.merged_cells);
#拆分单元格
#另一种拆分方式 ws.unmerge_cells("B2:D4")
ws.unmerge_cells(start_row=2,start_column=2,end_row=4,end_column=4);
4.6行高列宽设置
# 设定行高
ws.row_dimensions[2].height = 20;
# 设定列宽
ws.column_dimensions["B"].width = 30;

5矩阵置换

#先获取excel工作表的数据,把excel数据封装成列表
data_ls = [];
for cell_tp in ws.values:
    ls = [];
    for cell_value in cell_tp:
        ls.append(cell_value);
    data_ls.append(ls);
print(data_ls);  # [[xx,xx],[xx,xx]]
# 矩阵置换,行变列,列变行
# zip()返回的是一个对象,需要转换成list才能看到数据,且列表里面是元组
# *号的作用是把最外层的列表解包
conver_ls = list(zip(*data_ls));
print(conver_ls)  # [(xx,xx),(xx,xx)]

6总结

以上都是一些我操作excel常用的方法,等以后还有一些常用但是遗漏掉的再补充

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值