pathon基础2
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)
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';
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';
writeLogfile(logName,logstr)
#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';
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';
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的更多相关文章
- pathon 基础学习-集合(set),单双队列,深浅copy,内置函数
一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在pyt ...
- 【pathon基础】初识python
一.python的起源 作者:Guido van Rossum(龟叔) 设计原则:优雅,简单,明确 二.解释型语言VS编译型语言 1.解释型语言:C#.python step1:程序员写代码: ste ...
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- node-webkit 环境搭建与基础demo
首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Golang, 以17个简短代码片段,切底弄懂 channel 基础
(原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...
- [C#] C# 基础回顾 - 匿名方法
C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...
- HTTPS 互联网世界的安全基础
近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
随机推荐
- zk下的kafka节点
zk从某种程度上说是kafka的单点失效组件. /brokers:里面保存了Kafk集群的所有信息,包括每台broker的注册信息,集群上所有topic的信息等. /controller:保存了Kaf ...
- 安全的字符串拷贝strcpy_s的实现与理解
在C标准库中提供了字符串拷贝函数strcpy,而微软则为为它提供了一个更安全的版本strcpy_s,其函数原型为 errno_t __cdecl strcpy_s( char* _Destinatio ...
- nacos单机,集群安装部署
nacos单机启动 准备 下载nacos安装包 下载地址 准备centos环境 (本次测试使用docker) PS C:\Users\Administrator> docker run -tid ...
- SQL优化之SQL 进阶技巧(上)
由于工作需要,最近做了很多 BI 取数的工作,需要用到一些比较高级的 SQL 技巧,总结了一下工作中用到的一些比较骚的进阶技巧,特此记录一下,以方便自己查阅,主要目录如下: SQL 的书写规范 SQL ...
- C#Excel导出注意事项
Excel 导出 1.首先在服务器中安装office ,并且要注册2.在组件服务中 设置Microsoft.excel.appliction 属性中设置自定义加network service用户并交互 ...
- Node.js 应用---定时给自己发送邮件
参照传智播客的视频所写代码. js代码: //引用superagent包,用于服务器发送http请求 const request = require('superagent'); //导入cheeri ...
- Docker 简介-基本概念(一)
1.前提知识 1.1 linux相关的基础知识 1.2 git相关的知识 2. Docker三要素 Docker主要包含3要素:镜像(image).容器(container).仓库(repositor ...
- Hive基本原理及配置Mysql作为Hive的默认数据库
Hive是什么? Hive是基于Hadoop之上的数据仓库: Hive是一种可以存储.查询.分析存储在hadoop中的大规模数据 Hive定义了简单的类SQL查询语言,成为HQL,它允许熟悉SQL的用 ...
- Java 8 中的方法引用,轻松减少代码量,提升可读性!
1. 引言 Java8中最受广大开发中喜欢的变化之一是因为引入了 lambda 表达式,因为这些表达式允许我们放弃匿名类,从而大大减少了样板代码,并提高了可读性. 方法引用是lambda表达式的一种特 ...
- 团队作业6——Alpha阶段项目复审
复审人:利国铭 复审人看什么: 软件的质量:解决原计划解决的问题了么,软件运行质量如何?用户有多少,用户反馈如何? 软件工程的质量:代码在哪里? 代码能在新的机器上构建成功么? 代码可维护性如何?每日 ...