• sunjiali


    
    
    # coding: utf-8
    import tkinter as tk
    from ttk import Button
    
    
    class Main(tk.Tk):
        def __init__(self):
            tk.Tk.__init__(self)
            self.geometry(self.getSize())
    
            tk.Label(self, height=1).grid(row=0, column=1)
            Button(self, text='钉钉数据', command=self.OpenDingDingFile, width=20).grid(row=1, column=3)
            tk.Label(self, width=15, text='钉钉数据地址:').grid(row=1, column=0)
            self.LB1 = tk.Label(self, width=40,text="")
            self.LB1.grid(row=1, column=1)
            tk.Label(self, width=4).grid(row=1, column=4)
            Button(self, text='考勤数据', command=self.OpenKaoQinFile, width=20).grid(row=2, column=3)
            tk.Label(self, width=15, text='考勤数据地址:').grid(row=2, column=0)
            self.LB2 = tk.Label(self, width=40,text="")
            self.LB2.grid(row=2, column=1)
            Button(self, text='合并', command=self.getResult, width=20).grid(row=3, column=3)
            tk.Label(self, height=3).grid(row=4, column=2)
            self.return_msg = tk.Label(self, text="")
            self.return_msg.grid(row=4, column=0, columnspan=4)
    
        def getSize(self):
            """
            :description: 获取窗口的大小
            :return: 返回需要的大小
            """
            curWidth = 600
            curHeight = 200
            scnWidth, scnHeight = self.maxsize()
            tmpcnf = '%dx%d+%d+%d' % (curWidth, curHeight,
                                      (scnWidth - curWidth) / 2, (scnHeight - curHeight) / 2 - 150)
            return tmpcnf
    
        def OpenKaoQinFile(self):
            pass
    
        def OpenDingDingFile(self):
            pass
    
        def getResult(self):
            pass
    
    

    wqwe

    # coding:utf-8
    from Main import Main
    from tkFileDialog import askopenfilename
    import tkMessageBox as tkMB
    from xl import FunctionInit
    import sys
    
    reload(sys)
    sys.setdefaultencoding("utf-8")
    
    
    class DingDing(Main):
        def __init__(self):
            Main.__init__(self)
            self.func = FunctionInit()
    
        def OpenDingDingFile(self):
            file_path = askopenfilename(filetypes=(("xls files", ("*.xls", "*.xlsx")),
                                                   ("All files", "*.*")))
            print type(file_path)
            if not file_path:
                self.return_msg["text"] = '没有导入文件'
            elif file_path[len(file_path) - 3:] != 'xls' and file_path[len(file_path) - 4:] != 'xlsx':
                print file_path[len(file_path) - 3:]
    
                self.return_msg["text"] = '不是xls或者xlsx文件'
            else:
                # flag, msg = self.func.comple(file_path)
                print file_path
                self.LB1["text"] = str(file_path)
    
        def OpenKaoQinFile(self):
            file_path = askopenfilename(filetypes=(("xls files", ("*.xls", "*.xlsx")),
                                                   ("All files", "*.*")))
            if not file_path:
                self.return_msg["text"] = '没有导入文件'
            elif file_path[len(file_path) - 3:] != 'xls' and file_path[len(file_path) - 4:] != 'xlsx':
                print file_path[len(file_path) - 3:]
                self.return_msg["text"] = '不是xls或者xlsx文件'
            else:
                # flag, msg = self.func.comple(file_path)
                self.LB2["text"] = str(file_path)
    
        def getResult(self):
            Lb2 = self.LB2["text"]
            Lb1 = self.LB1["text"]
            if Lb1 != '' and (Lb1[len(Lb1) - 3:] == 'xls' or Lb1[len(Lb1) - 4] == 'xlsx'):
                print "|", Lb2[len(Lb2) - 4], "|"
                if Lb2 != '' and Lb2[len(Lb2) - 4:] == 'xlsx':
                    flag, msg, file_name = self.func.comple(Lb1, Lb2)
                    self.return_msg["text"] = flag, msg, file_name
                else:
                    tkMB.askokcancel("温馨提示", "考勤数据地址不是xls或者xlsx文件")
    
            else:
                tkMB.askokcancel("温馨提示", "考勤数据地址不是xls或者xlsx文件")
    
    
    if __name__ == "__main__":
        dingding = DingDing()
        dingding.mainloop()
    
    
    # coding:utf-8
    import xlrd
    import sys
    from openpyxl import load_workbook
    import time
    reload(sys)
    sys.setdefaultencoding("utf-8")
    
    
    class FunctionInit():
        def comple(self, DataFromDing,DataFromKao):
            head = u'钉钉'
            FILE_NAME = str(time.strftime("%Y-%m-%d_%H%M%S", time.localtime())) + '.xlsx'
            FILE_NAME = head + FILE_NAME
            try:
                aworkbook = xlrd.open_workbook(DataFromDing)
                sheet1 = aworkbook.sheet_by_index(0)
                row3 = sheet1.row_values(3)
                len1 = len(row3)
                print len1
                s = ','.join(row3)
                s.decode('utf-8')
                emp = []
                emps = []
                employees = []
                row2 = sheet1.row_values(2)
                leave1 = int(row2.index('请假'.decode('utf-8').encode('utf-8')))
                print leave1
                len2 = 0
    
                for i in range(leave1, len1):
                    if row3[i] == '':
                        len2 = i
                        break
                le = []
                if leave1 > 0:
                    if len2 > 0:
                        for i in range(leave1, len2):
                            le.append(row3[i][:2])
                        for i in range(len2, len1):
                            le.append(row2[i][:2])
                    else:
                        for i in range(leave1, len1):
                            le.append(row3[i][:2])
                print len(le)
                f = open('c', 'w')
                emp = []
                print len(sheet1.col_values(3))
                for i in range(4, (len(sheet1.col_values(3)) - 4)):
                    dic = {}
                    dic['name'] = sheet1.row_values(i)[3].split('(')[0]
                    for ctype in le:
                        str_tmp = sheet1.row_values(i)[(le.index(ctype) + leave1)]
                        if str_tmp not in ['0', 0]:
                            print dic['name'],str_tmp[:len(str_tmp) - 2]
                            int_tmp = str_tmp[:len(str_tmp) - 2]
                            print '+++', str_tmp, '=='
                            dic[ctype] = int_tmp
                        else:
                            dic[ctype] = 0.0
    
                    emp.append(dic)
    
                f.close()
                employees = []
                a = load_workbook(DataFromKao)
                c = a['附1人员清单']
                for row in c.iter_rows('c:c'):
                    for cell in row:
                        employees.append(cell.value)
                list_leave = ['加班', '']
                for col in c.iter_rows('p1:y1'):
                    for cell in col:
                        list_leave.append(cell.value[:2])
                with open('a', 'w') as f:
                    f.write(','.join(list_leave))
                employees = employees[1:]
                for i in range(len(employees)):
                    for j in range(14, 26):
                        c.cell(row=i + 2, column=j, value=0.0)
                for i in range(len(employees)):
                    for j in range(len(emp)):
                        if employees[i] == emp[j]['name']:
                            print employees[i],
                            for key in emp[j]:
                                print list_leave
                                for tmp in range(len(list_leave)):
                                    if list_leave[tmp] == key and key != '':
                                        c.cell(row=(i + 2), column=tmp + 14, value=emp[j][key])
                                        # print i + 2, tmp + 14, key, emp[j][key],
                                        break
    
                                print '||',
                            print
                result_flag = True
                return_msg = '解析成功'
                a.save(filename=FILE_NAME)
            except Exception, e:
                result_flag = False
                return_msg = '解析失败'
                print e
            finally:
                return result_flag, return_msg,FILE_NAME
    
    
    if __name__ == "__main__":
        dingding = FunctionInit()
        dingding.comple('3.xls')
    
    
  • 相关阅读:
    解决ArrayList线程不安全
    TraceView工具的使用
    Service
    Android之移动热修复
    06 swap命令,进程管理,rmp命令与yum命令,源码安装python
    04 linux用户群组和权限
    03 linux命令的操作
    Unity 5.x 导入教学Demo
    Creo二次开发—内存处理
    求一个数的二进制数中所含1的个数的代码实现
  • 原文地址:https://www.cnblogs.com/jian-pan/p/6560168.html
Copyright © 2020-2023  润新知