download:Java Full stack engineer 【30 End of week 】

Half a year , Take you from the back end to the full stack
From the back end to the full stack CTO, I spent it. 10 year , this 10 Year is condensed into 120 More than one hour , my 10 year , You may only need half a year , I hope
You're luckier than me , Less groping for the way , To become competent for a higher position at a faster speed , More favored by the market full stack Engineers

coding=UTF-8
XingHe Studio File to MD5 and SHA1
Galaxy studio (XingHeStudio.com)
Create by Stream.Wang 2012-04-10
Modify by Stream.Wang 2012-04-10
def fil_changefileext(filename,extname=''):
FIL ChangeFileExt Change the file extension
filename Enter the file path name
extname='' To change the sub extension , Such as .txt
import os
try:
if extname[0]<>'.':
extname='.'+extname
except:
extname=''
if os.path.splitext(filename)[1]=='':
uouttxt=filename+'.'+extname
elif os.path.splitext(filename)[1]=='.':
uouttxt=filename+extname
else:
uouttxt=filename[:0-len(os.path.splitext(filename)[1])]+extname
return uouttxt
def fil_str2file(fstr,filename):

FIL STR2File Save the string to the file

try:
outfile=open(filename,'w')
outfile.writelines(fstr)
outfile.close()
return True
except:
return False

The main program of the system starts

if name == 'main':
import os,sys,math
if len(sys.argv)==1:sys.argv.append(r'c:\FreeNAS-8.0.4-RELEASE-x64.iso')
if len(sys.argv)>1:
filepathname=sys.argv[1]
if os.path.isfile(filepathname) :
fmaxs = os.path.getsize(filepathname)+0.00
fpos = 0.00
ppos=0
pmax=50
pjy=0
fmd5=fil_changefileext(filepathname,'.md5')
fsha1=fil_changefileext(filepathname,'.sha')
ffm=os.path.basename(filepathname)
Start disposal
print 'Program Runing "'+filepathname+'" ...'
import hashlib
try:
umd5str = hashlib.md5()
usha1str = hashlib.sha1()
xfilepathname=unicode(filepathname,'utf8')
Need to use binary format to read file content
ufile = file(xfilepathname,'rb')
while True:
datas = ufile.read(1024512)
if not datas: break
umd5str.update( datas )
usha1str.update( datas )
fpos=fpos+1024
512
ppos=int(math.floor(fpos / fmaxs 50))
pposbfh=int(math.floor(fpos / fmaxs
100))
Print progress bar
if pjy<>ppos: print '['+''ppos +'='(pmax-ppos)+'] '+str(pposbfh) +'%'
Print progress issues not addressed , Don't know print How the function returns to the beginning of the line to mask the output , I know if I don't change my career , Add a “,”
pjy=ppos
uoutstrmd5=str(umd5str.hexdigest())
uoutstrsha1=str(usha1str.hexdigest())
ufile.close()
print ''
fil_str2file(uoutstrmd5+'
'+ffm+'\n',fmd5)
fil_str2file(uoutstrsha1+' *'+ffm+'\n',fsha1)
print 'Task is completed !' + r' [ XingHe Studio File to MD5 and SHA1 ]'
except:
print 'Error !' + r' [ XingHe Studio File to MD5 and SHA1 ]'
else:
print 'File "'+filepathname+'" not exist!'+ r' [ XingHe Studio File to MD5 and SHA1 ]'
else:
print r' [ XingHe Studio File to MD5 and SHA1 ]'