python 读取excel方法(最大行数:1048576)
首先需要导入 import openpyxl
1、打开excel,并且获取sheet
1 inwb=openpyxl.load_workbook(Path_generate) 2 Sheetnames=inwb.get_sheet_names() 3 ws=inwb.get_sheet_by_name(Sheetnames[0])
2,最大行数,列数
1 rows=ws.max_row 2 cols=ws.max_column
3,输出指定数值
1 print(ws.cell(1,1).value)
4,写:创造空白空间及sheet
1 outwb=openpyxl.Workbook() 2 outws=outwb.create_sheet(index=0)
5,写:写入信息
1 outws.cell(row, col).value = row * 2 # 写文件
6,保存文件
1 saveExcel = "D:\work\Excel_txtProcesss\test.xlsx" 2 outwb.save(saveExcel) # 一定要记得保存
汇总:
读取函数
1 def readExel(self): 2 filename = r'D:workExcel_txtProcesss ew-微博-合并58.xlsx' 3 inwb = openpyxl.load_workbook(filename) # 读文件 4 5 sheetnames = inwb.get_sheet_names() # 获取读文件中所有的sheet,通过名字的方式 6 ws = inwb.get_sheet_by_name(sheetnames[0]) # 获取第一个sheet内容 7 8 # 获取sheet的最大行数和列数 9 rows = ws.max_row 10 cols = ws.max_column 11 for r in range(1, rows): 12 for c in range(1, cols): 13 print(ws.cell(r, c).value) 14 if r == 10: 15 break
写函数
1 def writeExcel(self): 2 outwb = openpyxl.Workbook() # 打开一个将写的文件 3 outws = outwb.create_sheet(index=0) # 在将写的文件创建sheet 4 for row in range(1, 70000): 5 for col in range(1, 4): 6 outws.cell(row, col).value = row * 2 # 写文件 7 print(row) 8 saveExcel = "D:\work\Excel_txtProcesss\test.xlsx" 9 outwb.save(saveExcel) # 一定要记得保存
背景:需要生成类似自动化case格式的那种excel表格
覆盖式写入:
献上代码:
import xlrd
import openpyxl
from xlutils.copy import copy
#覆盖式写入,定义覆盖写入excel函数
def WriteExcel(path, sheet_name):
”’
# :param sheet_name: 需要改写的sheet_name
# :param path: 工作薄的路径
# :return:
# ”’
workbook = openpyxl.Workbook()
sheet = workbook.active
sheet.title = sheet_name
k_list = []
v_list = []
for k,v in value_dict.items():
k_list.append(k)
v_list.append(v)
for i in range(0, len(k_list)):
sheet.cell(row=1, column=i + 1, value=k_list[i])
for j in range(0, len(v_list)):
sheet.cell(row=i + 2, column=j + 1, value=v_list[j])
workbook.save(path)
print(“xlsx格式表格【覆盖】写入数据成功!”)
if __name__ == ‘__main__’:
#定义工作薄的路径
path = ‘/Users/dongyue/Desktop/code/leecode/xlsx格式demo.xlsx’
#定义要写入的行和列的值
value_dict = {
“请求方法”:”post”,
“请求参数”:”测试参数”,
“返回参数”:”测试参数”,
“预期结果”:”successful”,
“实际结果”:”successful”,
}
#定义excel的sheet_name “xlsx格式测试表 ”
sheet_name = “xlsx格式测试表”
WriteExcel(path,sheet_name)
执行结果是:
excel中的显示是:
这个在第二次执行的时候会覆盖原来的内容,所以这种是全部覆盖式的写入。
追加式写入:
献上代码:
import xlrd
import openpyxl
from xlutils.copy import copy
#append写入,定义追加写入excel函数
def WriteExcelAppend(path):
”’
:param line_number: 行数
:param path: 工作薄的路径
:return:
”’
workbook = xlrd.open_workbook(path) #打开工作薄
sheets_name = workbook.sheet_names() #获取工作薄的所有的sheet名称
worksheet = workbook.sheet_by_name(sheets_name[0]) #获取工作薄中的第一个sheet
rows_exists = worksheet.nrows #获取已经存在的数据行数
new_workbook = copy(workbook) #将xlrd对象拷贝转化为xlwt对象
new_worksheet = new_workbook.get_sheet(0) #获取转化后的第一个表格
v_list = []
for k, v in value_dict.items():
v_list.append(v)
for j in range(0, len(v_list)):
new_worksheet.write(rows_exists, j, v_list[j])
new_workbook.save(path) # 保存工作簿
print(“xls格式表格【追加】写入数据成功!”)
if __name__ == ‘__main__’:
#定义工作薄的路径
path = ‘/Users/dongyue/Desktop/code/leecode/xlsx格式demo.xlsx’
#定义要写入的行和列的值
value_dict = {
“请求方法”:”post”,
“请求参数”:”测试参数”,
“返回参数”:”测试参数”,
“预期结果”:”successful”,
“实际结果”:”successful”,
}
#定义excel的sheet_name “xlsx格式测试表 ”
sheet_name = “xlsx格式测试表”
WriteExcelAppend(path)
在执行之前我在excel中备注下:
希望达到的预期是在这行之后进行追加
执行结果为:
excel中的展示
我在追加的时候只追加了一条数据,如果小伙伴们想追加多条,可以进行循环。这种的数据是我们自行写死的,在测试过程中的话,是需要拉取各种参数,然后进行写入的,我们可以获取各种参数后,给他处理成dict形式。
还有就是如果想自行的让代码看这个操作是执行追加还是覆盖的话。可以先获取下,已经存在的行数(上面的代码中有),如果值等于0,就说明该表中没有数据,可以执行覆盖式的写入,如果值大于0,就需要进行追加式写入。
现在的excel表格是这样的:
将下方代码进行更改
if __name__ == ‘__main__’:
#定义工作薄的路径
path = ‘/Users/dongyue/Desktop/code/leecode/xlsx格式demo.xlsx’
#定义要写入的行和列的值
value_dict = {
“请求方法”:”post”,
“请求参数”:”测试参数”,
“返回参数”:”测试参数”,
“预期结果”:”successful”,
“实际结果”:”successful”,
}
#定义excel的sheet_name “xlsx格式测试表 ”
sheet_name = “xlsx格式测试表”
workbook = xlrd.open_workbook(path)
sheets_name = workbook.sheet_names()
worksheet = workbook.sheet_by_name(sheets_name[0])
rows_exists = worksheet.nrows
if rows_exists == 0:
WriteExcel(path,sheet_name)
else:
WriteExcelAppend(path)
其中取出的是第一个sheet,此时是有数据,这种情况下执行应该是进行追加。执行结果如下:
excel中展示:
如果将worksheet = workbook.sheet_by_name(sheets_name[0]) 后面的sheets_name[0]改为sheets_name[1],此时获取的就是sheet_name为ceshi的那个表格,这个表格是没有数据的。所以我们此时执行就是覆盖写入,并且之前的sheet是没有了的。
执行结果如下:
excel展示:
——————
====================================
——————————
版权声明:本文为CSDN博主「Mojitoice」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Mojitoice/article/details/107020961
您的位置: 网站首页> openpyxl教程> 当前文章
openpyxl删除单行删除多行
删除行与列:
woeksheet.delete_rows(row)#这里填的行数从1开始,1是第一行,所以上面的0是无效的
删除列也是同样可以
woeksheet.delete_cols(row)
点击领取>>python全套教程
点击领取>>js逆向_app逆向_安卓群控
delete_rows可以指定删除一行也可以删除多行,默认删除一行。官方文档如下:
openpyxl.worksheet.worksheet.Worksheet.delete_rows() delete_rows(idx, amount=1) Delete row or rows from row==idx
下面的代码演示openpyxl在excel中追加一行、删除第1行、删除第1到3行(删除行和清空行数据不同,删除行后下面的行会往上移)。
- # -*- coding: utf-8 -*-
- from openpyxl import Workbook
- wb = Workbook() # 默认生成一个名为Sheet的sheet
- # 创建sheet
- for name in [‘a’,‘b’]:
- ws = wb.create_sheet(name)
- # 追加行
- for sheet in wb:
- for i in range(1,5):
- sheet.append([‘a’+str(i),‘b’+str(i)])
- # 删除第一行
- for sheet in wb:
- sheet.delete_rows(1)
- # 删除从1到3行
- for sheet in wb:
- sheet.delete_rows(1,3)
- wb.save(‘test.xlsx’)