支持不同文件,不同sheet页
import xlrd
import xlwt
import os
import time;
#往日志文件中追加内容函数
def writeLogfile(filename,content):
    file=open(filename,'a') #以追加方式打开日志文件
    time_now= time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())  #系统时间格式化
    file.writelines(time_now+':'+content+'\n')      #写入内容
    file.close() #关闭文件
   
def read_excel(srcPath,tarPath,srcName,tarName):
    print(srcPath);
    print(tarPath);
    print(srcName);
    print(tarName);
    src_xls={}
    tar_xls={}
    src=xlrd.open_workbook(srcPath)
    tar=xlrd.open_workbook(tarPath)
    startime=time.strftime("%Y-%m-%d:%H:%M:%S",time.localtime())
    print(startime,'开始对比。。。')
    logName = 'log_'+startime[0:10]+'.log'
    logfile = open(logName,'w')
    logfile.writelines(startime+':[开始对比]...'+'\n')
    logfile.close()
    try:
        sheetSrc = src.sheet_by_name(srcName)
        sheetTar = tar.sheet_by_name(tarName)
        if sheetSrc.name == srcName:
            for row in range(0,sheetSrc.nrows):
                #获取行内容行号列号从0开始
                #获取列内容
                rowDesc=sheetSrc.row_values(row)
                #colDesc = sheetSrc.col_values(row)
                print(rowDesc)
                #print(colDesc)
                #获取列内容
                colDesc=rowDesc[0]
                print(colDesc)
                #print(type(colDesc))
                colDesc2 = rowDesc[1]
                print(colDesc2)
                #print(type(colDesc))
                src_xls[colDesc]=colDesc2
               
        if sheetTar.name == tarName:
            for row in range(0,sheetTar.nrows):
                #获取行内容行号列号从0开始
                #获取列内容
                rowDesc=sheetTar.row_values(row)
                #colDesc = sheetSrc.col_values(row)
                print(rowDesc)
                #print(colDesc)
                #获取列内容
                colDesc=rowDesc[0]
                print(colDesc)
                #print(type(colDesc))
                colDesc2 = rowDesc[1]
                print(colDesc2)
                #print(type(colDesc))
                tar_xls[colDesc]=colDesc2
               
        result = {}
        errcount = 0
        srccount = 0
        tarcount = 0
        for srcDes in list(src_xls.keys()):
            #if tar_xls.has_key(srcDes): pathon 已经删除了has_key
            if srcDes not in tar_xls.keys():
                srccount+=1
                #logstr =' '+str(srcDes) +' '+str(src_xls[srcDes]) +' false';
                logstr=" ".join([str(srcDes),str(src_xls[srcDes]),false])
                writeLogfile(logName,str(logstr))
                result[errcount] = logstr
                errcount+=1
                continue
            for tarDes in list(tar_xls.keys()):
                if srcDes == tarDes and float(src_xls[tarDes]) == float(tar_xls[tarDes]):
                    #logstr =' '+str(srcDes) +' '+str(src_xls[srcDes]) + ' ' + str(tarDes) + ' ' + str(tar_xls[tarDes])+' true';
                    logstr = " ".join([str(srcDes),str(src_xls[srcDes]),str(tarDes),str(tar_xls[tarDes]),' true'])
                    writeLogfile(logName,logstr)
                    del src_xls[tarDes]
                    del tar_xls[tarDes]
                    continue
                    #result[errcount] = logstr
                    #errcount += 1
                elif srcDes == tarDes and float(src_xls[tarDes]) != float(tar_xls[tarDes]):
                   # logstr =' '+str(srcDes) +' '+str(src_xls[srcDes]) + ' ' + str(tarDes) + ' ' + str(tar_xls[tarDes])+ str(float(src_xls[tarDes])-float(tar_xls[tarDes]) )+ ' false';
                    logstr=" ".join([str(srcDes),str(src_xls[srcDes]),str(tarDes),str(tar_xls[tarDes]),str(float(src_xls[tarDes])-float(tar_xls[tarDes]) ), false])
                    writeLogfile(logName,str(logstr))
                    result[errcount] = logstr
                    errcount += 1
                    continue
        for tarDes in tar_xls:
                if(tarDes not in src_xls.keys()):
                    tarcount+=1
                    #logstr =' '+str(tarDes) +' '+str(tar_xls[tarDes]) +' false';
                    logstr = " ".join([str(tarDes),str(tar_xls[tarDes]),false])
                    writeLogfile(logName,str(logstr))
                    result[errcount] = logstr
                    errcount+=1
        writeLogfile(logName,'对比完成!!!错误数{:d}'.format(errcount))
        writeLogfile(logName,'对比完成!!!原数据文件独有{:d}'.format(srccount))
        writeLogfile(logName,'对比完成!!!目标数据文件独有{:d}'.format(tarcount))
        writeLogfile(logName,'差异数据:')
        for res in result:
            logstr =' '+str(res) +' '+result[res] ;
            writeLogfile(logName,str(logstr))
                   
    except Exception as err:
        print(str(err))
        writeLogfile(logName,str(err))
   
def main():
    pass
if __name__ == '__main__':
    read_excel('1007006.xlsx','1007006.xlsx','Sheet1','Sheet2')

pathon基础2的更多相关文章

  1. pathon 基础学习-集合(set),单双队列,深浅copy,内置函数

    一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在pyt ...

  2. 【pathon基础】初识python

    一.python的起源 作者:Guido van Rossum(龟叔) 设计原则:优雅,简单,明确 二.解释型语言VS编译型语言 1.解释型语言:C#.python step1:程序员写代码: ste ...

  3. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  4. node-webkit 环境搭建与基础demo

    首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...

  5. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  6. Golang, 以17个简短代码片段,切底弄懂 channel 基础

    (原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...

  7. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  8. HTTPS 互联网世界的安全基础

    近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...

  9. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

随机推荐

  1. 这些鲜为人知的前端冷知识,你都GET了吗?

    背景 最近公司项目不多,比较清闲,划水摸鱼混迹于各大技术博客平台,瞬间又GET了好多前端技能,一些属于技巧,一些则是闻所未闻的冷知识,一时间还消化不过来,不由的发出一声感叹! 前端可真是博大精深 于是 ...

  2. 「刷题笔记」Tarjan

    贴一个讲得非常详细的\(tarjan\)入门教程 信息传递 讲个笑话:我之前用并查集求最小环过的这题,然后看见题目上有个\(tarjan\)标签 留下了深刻的印象:\(tarjan\)就是并查集求最小 ...

  3. Pycharm永久激活方法

    1.下载新版破解补丁 链接 https://pan.baidu.com/s/137-afPKYfkXbvroSv1hoYw 提取码: cm43  下载补丁文件jetbrains-agent.jar并将 ...

  4. Python机器学习笔记:异常点检测算法——LOF(Local Outiler Factor)

    完整代码及其数据,请移步小编的GitHub 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/MachineLearningNote 在数据挖掘方面,经常需 ...

  5. Android的Toolbar(含溢出菜单设置[弹出菜单的使用])的使用PopMenu的样式

    http://blog.csdn.net/yingtian648/article/details/52432438(转载) 1.在Toolbar.xml中设置弹出菜单的风格(app:popupThem ...

  6. 基于 MongoDB 动态字段设计的探索 (二) 聚合操作

    业务需求及设计见前文:基于 MongoDB 动态字段设计的探索 根据专业计算各科平均分 (总分.最高分.最低分) public Object avg(String major){ Aggregatio ...

  7. 零钱问题的动态规划解法——用 n 种不同币值的硬币凑出 m 元,最少需要多少硬币。

    输入格式:第一行输入需要凑的钱数 m 和硬币的种类 n (0<m<100,0<n<10),第二行输入 n 种硬币的具体币值,假设硬币供应量无限多. 输出格式:输出最少需要的硬币 ...

  8. DockerFile理解与应用

    1.DockerFile是什么? DockerFile是用来构建Docker镜像的构建文件,一般分为四部分:基础镜像信息.维护者信息.镜像操作指令和容器启动时执行指令,'#' 为 Dockerfile ...

  9. 第5.3节 详说Python风格的函数分配参数

    一.    分配参数的定义 参数收集就是在定义函数时不能确认参数个数,用收集参数将调用时不确定数量的实参存放到收集参数的元组中.分配参数与此过程相反,它不是在定义函数形参时使用星号(1个或2个),而是 ...

  10. PyQt学习随笔:QTableWidget的信号signal简介

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QTableWidget非继承自父类的信号如下: cellActivated(int row, in ...