本文用python中openpyxl库,封装成excel数据的读写方法
from openpyxl import load_workbook from openpyxl.worksheet.worksheet import Worksheet class ExcelHandler(): def __init__(self,file): self.file=file def open_sheet(self,name) ->Worksheet :
#表示此函数的返回值,是一个这样的类型,函数注解 wb=load_workbook(self.file)#通过属性传递 sheet=wb[name] return sheet def header(self,sheet_name): '''获取表头''' sheet=self.open_sheet(sheet_name) headers=[] for i in sheet[1]: headers.append(i.value) return headers def read(self,sheet_name): '''读取所有数据''' sheet=self.open_sheet(sheet_name) rows=list(sheet.rows)#得到所有的数据,包括表头 data=[]#存取所有行的数据 for row in rows[1:]: row_data=[]#存取一行的数据 for cell in row:#取出单元格 row_data.append(cell.value)#把单元格的值存在一行的数据中 #列表转字典,要和header zip data_dict=dict(zip(self.header(sheet_name),row_data)) data.append(data_dict)#把一行的值存在放所有行的数据中 print(data) return data @staticmethod def write(file,sheet_name,row,column,data): wb=load_workbook(file) sheet = wb[sheet_name]#获取表单 cell = sheet.cell(row,column)#获取单个单元格 cell.value = data#写入值 wb.save(file)#保存 wb.close() if __name__ == '__main__': excel=ExcelHandler(r'D:cases.xlsx') sheet=excel.read('Sheet1')