因为项目版本之间的diff比较常用到,一般都查看改动过的脚本的diff,尤其是看其他人写的代码的时候。有些情况是一个目录中有很多文件,到最后也不知道都改了哪里了,于是需要逐个diff。
于是就诞生了这个脚本,这也是很久之前刚开始写python的时候写的比较简陋的.
因为linux执行ll命令,不同的机器可能显示不太相同,可做相应调整,下面脚本适应的情况是:
total 12 drwxr-sr-x 3 work work 4096 Nov 22 16:43 bin drwxr-sr-x 2 work work 4096 Nov 8 10:30 conf -rw-rw-r-- 1 work work 64 Nov 22 15:27 test.pl
两个脚本构成,主要是思路是检测新代码目录中与旧目录中脚本的diff,如果新目录中有新出现的脚本也会发现。
运行脚本为go_diff.py,调用脚本为diff_work.py
go_diff.py
import os import sys if __name__ == '__main__': if len(sys.argv) == 4: print "yes,running" print "===============================================================" file1 = sys.argv[1] file2 = sys.argv[2] file3 = sys.argv[3] cmd = 'ls -l '+file1+' >temp_file1' os.system(cmd) cmd = 'ls -l '+file2+' >temp_file2' os.system(cmd) cmd = 'rm -rf '+file3+';mkdir '+file3 os.system(cmd) cmd = 'cat temp_file1 temp_file2|python diff_.py '+file1+' '+file2+' '+file3 os.system(cmd) cmd = 'rm temp_file1 temp_file2' os.system(cmd) print "===============================================================" # find_content(ff,int(sys.argv[1])) else: print "parameter num error ******" print "parameter1:content1" print "parameter2:content2" print "parameter3:dest_content"
diff_work.py
import sys import os def find_content(ff,file1,file2,file3): m = {} flag = 0 while True: ll = ff.readline().strip() if(ll): tokens = ll.split(' ') if(len(tokens) > 4 and tokens[0].find('drw')!=0): m[tokens[-1]] = 0 if(len(tokens) < 3 and flag!=0): break flag = 1 else: break n = {} while True: ll = ff.readline().strip() if(ll): tokens = ll.split(' ') if(len(tokens) > 4 and tokens[0].find('drw')!=0): n[tokens[-1]] = 0 else: break for x in m.keys(): if(n.has_key(x)): print x cmd = "diff %s/%s %s/%s > %s/%s" %(file1,x,file2,x,file3,x) os.system(cmd) else: print x cmd = 'cat %s/%s > %s/%s' %(file1,x,file3,x) os.system(cmd) if __name__ == '__main__': ff = sys.stdin if len(sys.argv) == 4: find_content(ff,sys.argv[1],sys.argv[2],sys.argv[3]) else: print "error"