实例介绍
【实例截图】

【核心代码】
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="有数据没有输入或数据输入错误!")
标签: Excel比对小软件
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论