标签:0.9 timeit python Accept kwargs deepcopy 替代 marshal
from copy import deepcopy
import marshal
import timeit
from multidict import CIMultiDict
def test_deepcopy():
_kwargs = CIMultiDict({
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9",
"Host": "www.discogs.com",
"User-Agent": ("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) "
"AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36"),
})
if _kwargs is None:
_kwargs = dict()
kwargs = deepcopy(_kwargs)
def test_marshal():
_kwargs = CIMultiDict({
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9",
"Host": "www.discogs.com",
"User-Agent": ("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) "
"AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36"),
})
if _kwargs is None:
_kwargs = dict()
kwargs = marshal.loads(marshal.dumps(dict(_kwargs)))
if __name__ == '__main__':
print(timeit.timeit(stmt=test_deepcopy, number=1000000))
print("=" * 30)
print(timeit.timeit(stmt=test_marshal, number=1000000))
测试发现deepcopy是比较耗时的
第一次
21.046875760000002
==============================
6.435647065000001
第二次
19.536858445
==============================
6.0979895100000014
标签:0.9,timeit,python,Accept,kwargs,deepcopy,替代,marshal 来源: https://www.cnblogs.com/c-x-a/p/12374692.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。