码迷,mamicode.com
首页 > 其他好文 > 详细

cesium纽约3dtiles数据下载

时间:2018-03-08 13:59:34      阅读:272      评论:0      收藏:0      [点我收藏+]

标签:文件的   def   rip   文件   lib   for   exception   取数据   request   

cesium示例有纽约的3dtiles数据,下载官方有下载链接,但是下载后为乱码。

因此研究了下,写了个爬虫解码下载,代码如下:

#coding=utf-8
from urllib import request
import os
import socket
import zlib

# python版本3.7
# 设置超时
socket.setdefaulttimeout(60)

def mkdir(path):
    
    # 去除首位空格
    path=path.strip()
    # 去除尾部 \ 符号
    path=path.rstrip("\\")
 
    # 判断路径是否存在
    # 存在     True
    # 不存在   False
    isExists=os.path.exists(path)
 
    # 判断结果
    if not isExists:
        # 如果不存在则创建目录
        # 创建目录操作函数
        os.makedirs(path) 
 
        print(path create success!)
        return True
    else:
        # 如果目录存在则不创建,并提示目录已存在
        print(path already exist!)
        return False
 
# 定义要创建的目录
mkpath="F:\\python\\cesiumData\\"
# 调用函数
#mkdir(mkpath)

def callbackfunc(blocknum, blocksize, totalsize):
    ‘‘‘回调函数
    @blocknum: 已经下载的数据块
    @blocksize: 数据块的大小
    @totalsize: 远程文件的大小
    ‘‘‘
    # percent = 100.0 * blocknum * blocksize / totalsize
    # if percent > 100:
        # percent = 100
    print("--")

#便利URL,获取数据
def getDataByUrl():
    str1="https://beta.cesium.com/api/assets/1461/"
    str2=".b3dm?access_token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiJiMTBjN2E3Mi03ZGZkLTRhYmItOWEzNC1iOTdjODEzMzM5MzgiLCJpZCI6NDQsImlhdCI6MTQ4NjQ4NDM0M30.B3C7Noey3ZPXcf7_FXBEYwirct23fsUecRnS12FltN8&v=1.0"
    for z in range(0,8):
        for x in range(0,2**z):
                path=str(z)+"\\"+str(x)
                temppath=mkpath+path
                mkdir(temppath)
                for y in range(0,2**z):
                    url=str(z) + / + str(x) + / + str(y)
                    str3=str1+ url + str2
                    try:
                        #urllib.urlretrieve(str3,url+‘.b3dm‘)
                        req = request.Request(str3)
                        req.add_header(Host, beta.cesium.com)
                        req.add_header(Connection, keep-alive)
                        req.add_header(Origin, https://cesiumjs.org)
                        req.add_header(User-Agent, Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36)
                        req.add_header(Accept, */*)
                        req.add_header(Referer, https://cesiumjs.org/NewYork/?view=-74.02572034279622%2C40.669539917125135%2C1364.6164107825127%2C21.27406391595569%2C-21.3627766554608%2C0.0706585523215407)
                        req.add_header(Accept-Encoding, gzip, deflate, br)
                        req.add_header(Accept-Language, zh-CN,zh;q=0.9)
                        with request.urlopen(req) as f:
                            #print(‘Status:‘, f.status, f.reason)
                            #for k, v in f.getheaders():
                                #print(‘%s: %s‘ % (k, v))
                            f2 = open(url+.b3dm, wb)
                            data=f.read()
                            html = zlib.decompress(data, 16+zlib.MAX_WBITS)
                            f2.write(html)
                    except Exception as e:
                        print(e)

getDataByUrl()

 

cesium纽约3dtiles数据下载

标签:文件的   def   rip   文件   lib   for   exception   取数据   request   

原文地址:https://www.cnblogs.com/dullfish/p/8527531.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!