forked from aaPanel/BaoTa
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdownloadFile.py
64 lines (61 loc) · 2.53 KB
/
downloadFile.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#coding: utf-8
# +-------------------------------------------------------------------
# | 宝塔Linux面板
# +-------------------------------------------------------------------
# | Copyright (c) 2015-2099 宝塔软件(http://bt.cn) All rights reserved.
# +-------------------------------------------------------------------
# | Author: 黄文良 <[email protected]>
# +-------------------------------------------------------------------
import os,sys,public,json,time
class downloadFile:
logPath = 'data/speed.json'
timeoutCount = 0;
oldTime = 0;
writeTime = 0;
down_count = 0;
#下载文件
def DownloadFile(self,url,filename):
try:
path = os.path.dirname(filename)
if not os.path.exists(path): os.makedirs(path)
import urllib,socket,ssl
try:
ssl._create_default_https_context = ssl._create_unverified_context
except:pass
socket.setdefaulttimeout(30)
self.pre = 0;
self.oldTime = time.time();
if sys.version_info[0] == 2:
urllib.urlretrieve(url,filename=filename,reporthook= self.DownloadHook)
else:
urllib.request.urlretrieve(url,filename=filename,reporthook= self.DownloadHook)
speed = self.GetSpeed()
speed['pre'] = 100;
speed['used'] = speed['total']
self.WriteLogs(json.dumps(speed));
except:
if self.timeoutCount > 5: return;
self.timeoutCount += 1
time.sleep(5)
self.DownloadFile(url,filename)
#下载文件进度回调
def DownloadHook(self,count, blockSize, totalSize):
used = count * blockSize
pre1 = int((100.0 * used / totalSize))
my_time = time.time()
if self.pre != pre1 or (my_time - self.writeTime) > 1:
dspeed = ((count -self.down_count) * blockSize) / (my_time - self.oldTime)
speed = {'name':'下载文件','total':totalSize,'used':used,'pre':self.pre,'speed':dspeed}
self.WriteLogs(json.dumps(speed))
self.pre = pre1
self.writeTime = my_time
self.down_count = count
self.oldTime = my_time
#取下载进度
def GetSpeed(self):
speedLog = public.ReadFile(self.logPath)
if not speedLog: return {'name':'下载文件','total':0,'used':0,'pre':0,'speed':0}
return json.loads(speedLog)
#写输出日志
def WriteLogs(self,logMsg):
public.WriteFile(self.logPath,logMsg)