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

'''

原文地址:https://www.cnblogs.com/jian-pan/p/6704848.html