时间:2021-05-22
Python没有自带openyxl,需要安装: pip install openyxl
打开excel文档: openyxl.load_workbook(excel地址) - 打开现有excel文件
openyxl.Workbook() - 新建一个excel文件
返回一个工作博对象
import openpyxl
wb = openpyxl.load_workbook("test.xlsx")
print(type(wb)) # <class 'openpyxl.workbook.workbook.Workbook'>
openpyxl.load_workbook()函数,传入一个存在的excel文件名称/excel文件名称+文件路径,返回一个workbook对象。
从workbook对象中获取工作表
import openpyxlwb = openpyxl.load_workbook("test.xlsx")# print(type(wb)) # <class 'openpyxl.workbook.workbook.Workbook'># 工作簿对象.sheetnames - 获取当前工作簿中所有表的名字# print(wb.sheetnames) ['Sheet1', 'Sheet2', 'Sheet3']# 工作簿对象.active - 获取当前活动表对应的Worksheet对象# print(wb.active) <Worksheet "Sheet1"># 工作簿对象[表名] - 根据表名获取指定表对象# print(wb["Sheet2"]) <Worksheet "Sheet2"># 表对象.title - 获取表对象的表名ws = wb["Sheet1"]# print(ws.title) Sheet1# 表对象.max_row - 获取表中最多有多少行# print(ws.max_row) 15# 表对象.max_column - 获取表有多少列print(ws.max_column) # 3从表中取得单元格
import openpyxlwb = openpyxl.load_workbook("test.xlsx")ws = wb["Sheet1"]# 表对象['列号行号'] - 获取指定列的指定行对应的单元格对象(单元格对象是 Cell 类的对象,列号是从A开始,行号是从1开始)a = ws["A1"]# print(a) # <Cell 'Sheet1'.A1># 单元格对象.value - 获取单元格中的内容print(a.value)# 单元格对象.row - 获取行号(数字1开始)print(a.row)# 单元格对象.column - 获取列号(数字1开始)print(a.column)# 单元格对象.coordinate - 获取位置(包括行号和列号)print(a.coordinate)# 表对象.iter_rows() - 一行一行的取row_s = ws.iter_rows()for a in row_s: for i in a: print(i.value)# 表对象.iter_cols() - 列表一列的取col_s = ws.iter_cols()for c in col_s: for j in c: print(j.value)用字母来指定列时会出现列Z之后用两个字母代替,可以调用表的cell()方法,传入整数作为行数和列数,第一行或者第一列的整数是1,而不是0
表对象.cell(行号,列号)
import openpyxlwb = openpyxl.load_workbook("test.xlsx")ws = wb["Sheet1"]# 获取第二列的所有内容max_row = ws.max_rowfor row in range(1, max_row + 1): cell = ws.cell(row, 2) print(cell.value)从表中取得列和行
取电子表格中一行、一列或一个矩形区域中的所有 Cell 对象
表对象[位置1:位置2] 获取指定范围内的所有单元格
import openpyxlfrom openpyxl.utils import get_column_letter, column_index_from_stringwb = openpyxl.load_workbook("test.xlsx")ws = wb["Sheet1"]max_row = ws.max_rowcolumn = get_column_letter(max_row)# 获取第一列所有单元格对象row2 = ws["A1":f"{column}1"]ss = [(cell.coordinate, cell.value) for cells in row2 for cell in cells]print(ss)创建并保存Excel文档
openpyxl.Workbook() - 创建空的Excel文件对应的工作薄对象
工作薄对象.save(文件路径) - 保存文件
import openpyxlwb = openpyxl.load_workbook("test.xlsx")ws = wb["Sheet1"]# 修改sheet的名称ws.title = "hello_world"wb.save("test.xlsx")创建和删除sheet
工作薄对象.create_sheet(title, index) - 在指定工作薄中的指定位置(默认是最后)创建指定名字的表,并返回表对象
工作薄对象.remove(表对象) - 删除工作薄中的指定表
import openpyxlwb = openpyxl.load_workbook("test.xlsx")wb.create_sheet()print(wb.sheetnames)wb.create_sheet("test1")print(wb.sheetnames)wb.create_sheet("test2", index=0)print(wb.sheetnames)wb.remove(wb["test2"])print(wb.sheetnames)wb.save("test.xlsx")将数据写入表格中
import openpyxlwb = openpyxl.load_workbook("test.xlsx")ws = wb["hello_world"]# 方式一ws["A4"] = "hello_world"# 方式二ws.cell(4, 5).value = "hello_test"wb.save("test.xlsx")设置单元格样式
用表格展示数据的时候,有的时候需要对不同的数据以不同的风格进行展示从而达到分区或者强调的作用。
import openpyxlfrom openpyxl.styles import Font, PatternFill, Border, Side, Alignment# 1.打开工作薄wb = openpyxl.load_workbook("test.xlsx")ws = wb["hello_world"]# 2.设置单元格字体样式"""Font( name=None, # 字体名,可以用字体名字的字符串 strike=None, # 删除线,True/False color=None, # 文字颜色 size=None, # 字号 bold=None, # 加粗, True/False italic=None, # 倾斜,Tue/False underline=None # 下划线, 'singleAccounting', 'double', 'single', 'doubleAccounting')"""# 1:创建字体对象font1 = Font( size=20, italic=True, color="ff0000", bold=True, strike=True)# 2:设置指定单元格的字体# 单元格对象.font = 字体对象ws["B2"].font = font1# 3:设置单元格填充样式"""PatternFill( fill_type=None, # 设置填充样式: 'darkGrid', 'darkTrellis', 'darkHorizontal', 'darkGray', 'lightDown', 'lightGray', 'solid', 'lightGrid', 'gray125', 'lightHorizontal', 'lightTrellis', 'darkDown', 'mediumGray', 'gray0625', 'darkUp', 'darkVertical', 'lightVertical', 'lightUp' start_color=None # 设置填充颜色)"""fill = PatternFill( fill_type="solid", start_color="ffff00")ws["B2"].fill = fill# 设置单元格对齐样式al = Alignment( horizontal="right", # 水平向方: center 靠左:left 靠右: right vertical="top" # 垂直方向: center, top, bottom)ws["B2"].alignment = al# 设置边框样式# 设置边对象(四个边可以是一样的也可以不同,如果不同就创建多个Side对象)side = Side(border_style="thin", color="0000ff")# 设置边框对象(left、right、top、bottom表示的是边框的四个边,这儿四个边使用的是一个边对象)db = Border(left=side, right=side, top=side, bottom=side)ws["B2"].border = db# 设置单元格的宽度和高度# 设置指定列的宽度ws.column_dimensions["A"].width = 20# 设置指定行的高度ws.row_dimensions[1].height = 45wb.save("test.xlsx")以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了python读取Excel实例的具体代码,供大家参考,具体内容如下1.操作步骤:(1)安装python官方Excel库-->xlrd(2)获
本文实例为大家分享了python操作EXCEL的实例源码,供大家参考,具体内容如下读EXCEL的操作:把excel的数据存储为字典类型#coding=utf8#
这篇文章主要介绍了python操作openpyxl导出Excel设置单元格格式及合并处理代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的
本文实例讲述了python实现与redis交互操作。分享给大家供大家参考,具体如下:相关内容:redis模块的使用安装模块导入模块连接方式连接池操作设置值获取值
在Python中通过GET来获取页面的COOKIE是非常简单的事情,下面的代码实例演示了如何利用Python获取COOKIE内容#!/usr/bin/envpy