Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PALM
提交
19370b22
P
PALM
项目概览
PaddlePaddle
/
PALM
通知
5
Star
3
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PALM
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
19370b22
编写于
11月 28, 2019
作者:
W
wangxiao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update downloader.py
上级
d2bbdfd0
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
42 addition
and
47 deletion
+42
-47
paddlepalm/downloader.py
paddlepalm/downloader.py
+42
-47
未找到文件。
paddlepalm/downloader.py
浏览文件 @
19370b22
...
...
@@ -33,6 +33,44 @@ _items = {
'tasktype'
:
{
'utils'
:
None
},
}
def
_download
(
item
,
scope
,
path
,
silent
=
False
):
if
not
silent
:
print
(
'Downloading {}: {} from {}...'
.
format
(
item
,
scope
,
_items
[
item
][
scope
]))
data_url
=
_items
[
item
][
scope
]
data_dir
=
path
+
'/'
+
item
+
'/'
+
scope
if
not
os
.
path
.
exists
(
data_dir
):
os
.
makedirs
(
os
.
path
.
join
(
data_dir
))
filename
=
data_dir
+
'/'
+
data_url
.
split
(
'/'
)[
-
1
]
def
chunk_report
(
bytes_so_far
,
total_size
):
percent
=
float
(
bytes_so_far
)
/
float
(
total_size
)
if
percent
>
1
:
percent
=
1
if
not
silent
:
print
(
'
\r
>> Downloading... {:.1%}'
.
format
(
percent
),
end
=
""
)
def
chunk_read
(
response
,
url
,
chunk_size
=
16
*
1024
,
report_hook
=
None
):
total_size
=
response
.
info
().
getheader
(
'Content-Length'
).
strip
()
total_size
=
int
(
total_size
)
bytes_so_far
=
0
with
open
(
"%s"
%
filename
,
"wb"
)
as
f
:
while
1
:
chunk
=
response
.
read
(
chunk_size
)
f
.
write
(
chunk
)
f
.
flush
()
bytes_so_far
+=
len
(
chunk
)
if
not
chunk
:
break
if
report_hook
:
report_hook
(
bytes_so_far
,
total_size
)
return
bytes_so_far
response
=
urlopen
(
data_url
)
chunk_read
(
response
,
data_url
,
report_hook
=
chunk_report
)
if
not
silent
:
print
(
' done!'
)
def
_convert
():
raise
NotImplementedError
()
...
...
@@ -42,59 +80,16 @@ def download(item, scope='all', path='.'):
item
=
item
.
lower
()
scope
=
scope
.
lower
()
assert
item
in
_items
,
'{} is not found. Support list: {}'
.
format
(
item
,
list
(
_items
.
keys
()))
# if not os.path.exists(path + '/' + item):
# os.makedirs(os.path.join(path + '/' + item))
def
_download
(
item
,
scope
,
silent
=
False
):
if
not
silent
:
print
(
'Downloading {}: {} from {}...'
.
format
(
item
,
scope
,
_items
[
item
][
scope
]))
data_url
=
_items
[
item
][
scope
]
data_dir
=
path
+
'/'
+
item
+
'/'
+
scope
if
not
os
.
path
.
exists
(
data_dir
):
os
.
makedirs
(
os
.
path
.
join
(
data_dir
))
filename
=
data_dir
+
'/'
+
data_url
.
split
(
'/'
)[
-
1
]
def
chunk_report
(
bytes_so_far
,
total_size
):
percent
=
float
(
bytes_so_far
)
/
float
(
total_size
)
*
100.0
if
percent
>
100
:
percent
=
100
if
not
silent
:
print
(
'
\r
>> Downloading... %.1f%%'
%
percent
,
end
=
"
\r
"
)
def
chunk_read
(
response
,
url
,
chunk_size
=
16
*
1024
,
report_hook
=
None
):
total_size
=
response
.
info
().
getheader
(
'Content-Length'
).
strip
()
total_size
=
int
(
total_size
)
bytes_so_far
=
0
with
open
(
"%s"
%
filename
,
"wb"
)
as
f
:
while
1
:
chunk
=
response
.
read
(
chunk_size
)
f
.
write
(
chunk
)
f
.
flush
()
bytes_so_far
+=
len
(
chunk
)
if
not
chunk
:
break
if
report_hook
:
report_hook
(
bytes_so_far
,
total_size
)
return
bytes_so_far
response
=
urlopen
(
data_url
)
chunk_read
(
response
,
data_url
,
report_hook
=
chunk_report
)
if
not
silent
:
print
(
'done!'
)
if
_items
[
item
][
'utils'
]
is
not
None
:
_download
(
item
,
'utils'
,
silent
=
True
)
_download
(
item
,
'utils'
,
path
,
silent
=
True
)
if
scope
!=
'all'
:
assert
scope
in
_items
[
item
],
'{} is not found. Support scopes: {}'
.
format
(
item
,
list
(
_items
[
item
].
keys
()))
_download
(
item
,
scope
)
_download
(
item
,
scope
,
path
)
else
:
for
s
in
_items
[
item
].
keys
():
_download
(
item
,
s
)
_download
(
item
,
s
,
path
)
def
ls
(
item
=
None
,
scope
=
'all'
):
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录