class excel_compare(QWidget): def __init__(self): QWidget.__init__(self) self.compare_ui = excel多功能比对界面.Ui_Form() self.compare_ui.setupUi(self) def excel_true_false(): if window.compare_ui.lineEdit.text() and window.compare_ui.lineEdit_2.text() and window.compare_ui.lineEdit_3.text() and window.compare_ui.lineEdit_4.text() and window.compare_ui.lineEdit_5.text() and window.compare_ui.lineEdit_6.text() and window.compare_ui.lineEdit_7.text(): file_path_original = r'' str(window.compare_ui.lineEdit.text())#转义文件路径,怕有奇葩名字 data_original = xlrd.open_workbook(file_path_original) #获取sheet table_original = data_original.sheet_by_name(str(window.compare_ui.lineEdit_3.text())) #获取总行数 nrows_original = table_original.nrows #获取总列数 ncols_original = table_original.ncols li_original = [] for i in range(1,nrows_original): # print("333") cell_value = table_original.cell(i,int(window.compare_ui.lineEdit_4.text()) - 1).value li_original.append(cell_value) # print(li_original) file_path_target = r'' str(window.compare_ui.lineEdit_2.text()) data_target = xlrd.open_workbook(file_path_target) # 获取sheet table_target = data_target.sheet_by_name(window.compare_ui.lineEdit_5.text()) # 获取总行数 nrows_target = table_target.nrows # 获取总列数 ncols_target = table_target.ncols # global li_target li_target = [] for u in range(1, nrows_target): cell_value = table_target.cell(u, int(window.compare_ui.lineEdit_6.text()) - 1).value li_target.append(cell_value) # print(li_target) # print(li_target) # file_path_original = r'E:\python项目\EXCEL对比\test.xls' # w_sheet = wbook.get_sheet(0) # 索引sheet表 # print("123") original_file = pd.ExcelFile(file_path_original) original_sheetnames = original_file.sheet_names # print(original_sheetnames) for original_sheetnames_index in range(0,len(original_sheetnames)): if window.compare_ui.lineEdit_3.text() == original_sheetnames[original_sheetnames_index]: original_sheetnames_INDEX = original_sheetnames_index rbook = xlrd.open_workbook(file_path_original) # 打开文件 wbook = copy.copy(rbook) # 复制文件并保留格式 w_sheet = wbook.get_sheet(original_sheetnames_INDEX) # 索引sheet表 a = int(window.compare_ui.lineEdit_7.text()) - 1 for index in range(0,len(li_original)): if li_original[index] in li_target: w_sheet.write(index 1,a, "true") else: w_sheet.write(index 1,a, "false") wbook.save(file_path_original) # 保存文件 root = tk.Tk() root.withdraw() msgbox.showerror(title="提示", message="比对完成") else: root = tk.Tk() root.withdraw() msgbox.showerror(title="警告", message="有数据没有输入或数据输入错误!")
用户评论
推荐下载
-
常用小工具
个人在研究西门子PPI协议过程中开发的小工具,功能包括:IEEE754标准的十六进制与十进制相互转换、PPI协议FCS校验码生成、十进制十六进制二进制八进制相互转换、IIP协议偏移地址计算。
36 2019-09-19 -
美化小工具
原版WIN7小工具,美化大集合,绝对无毒
27 2019-09-20 -
msde小工具
使用msde没有企业管理器,这个工具实现了,sqlserver的企业管理器
23 2019-09-03 -
下载小工具
一个类似下载的小工具,可以参考,好吧,可以让你们学到不少东西的哟
38 2019-08-19 -
计时小工具
一个倒计时小工具,可用时公司竞聘答辩,系统支持自定义,支持到时提醒
15 2019-09-03 -
编码小工具
基于.NET4.0的编码转换小工具,备份一个,方便使用。
23 2019-09-04 -
Matlab小工具
用C#写的Matlab小工具,用于将stateflow的数据字典生成RTE层的代码,检查信号的使用率
30 2019-09-05 -
画图小工具
简单画图小工具,图形选择,正方形,圆形,矩形,还可以选择字体颜色
20 2019-09-06 -
正则小工具
工具由本人个人开发,结大家分享一下。
23 2019-09-10 -
开发小工具
取色小工具,对图片取色,带有像素尺.灵活好用.
24 2019-09-13
暂无评论