zoukankan      html  css  js  c++  java
  • DingDIng

    '''

    coding:utf-8

    from Main import Main
    from tkFileDialog import askopenfilename
    import tkMessageBox as tkMB
    from xl import FunctionInit
    import sys
    import os
    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')

    '''

    '''

    jianpan

    '''

  • 相关阅读:
    刷题-力扣-120. 三角形最小路径和
    刷题-力扣-1738. 找出第 K 大的异或坐标值
    刷题-力扣-96. 不同的二叉搜索树
    刷题-力扣-64. 最小路径和
    刷题-力扣-1734. 解码异或后的排列
    刷题-力扣-63. 不同路径 II
    刷题-力扣-62. 不同路径
    课程作业 02 动手动脑 2017.10.13
    课程作业 02 2017.10.13
    课程作业01 感想
  • 原文地址:https://www.cnblogs.com/jian-pan/p/6704848.html
Copyright © 2011-2022 走看看