python - 用curl如何curl
問題描述
curl -s -X POST -u cu2:l5f7jrRQttWdxsLmY7FV4+MA= -H 'Accept:application/xml' -H 'Date:Fri, 14 Apr 2017 02:07:17 GMT' -d 'date=2017-04-13&channel=vod.tv.cn&isExactMatch=false®ion=&startdate=2017-04-13&enddate=2017-04-14' http://opencenter.com/myview/bandwidth-origin
像這樣一個又帶-u-H-d的url要怎么用python通過curl訪問并獲取返回結(jié)果?
問題解答
回答1:推薦你修改一下問題標(biāo)題。
根據(jù)你的說法,其實(shí)你提供的代碼已經(jīng)可以運(yùn)行,只是你不知道如何獲取其輸出。
看你標(biāo)了 Python,其實(shí)你只需要復(fù)制一份 Python 執(zhí)行終端命令的代碼你就懂了。
回答2:已經(jīng)找到方法了,很多人會去用到pycurl,可是我百度找了下都只寫了代碼,代碼含義都沒有寫,后來找到了`http://docs.python-requests.org/zh_CN/latest/user/quickstart.html`真的是個好東西,里面有關(guān)于requests模塊的詳細(xì)說明。簡單分析下我的需求,1、http請求 2、‘-u’身份驗(yàn)證 3、‘-H’請求header頭 4、‘-d’請求參數(shù),理清思路再看文檔就簡單多了(剛開始我連-H是什么意思都沒弄明白)。import requestsurl = ’http://opencenter.com/myview/bandwidth-origin’##定義http請求的地址,即1headers = {’Accept’: 'application/xml',’Date’:’Fri, 14 Apr 2017 02:07:17 GMT’}##定義header頭,用dict方式定義,即3data = {’channel’: ’vod.tv.cn’, ’dataformat’: ’json’,’date’:’2017-04-13’}##定義參數(shù),同樣用dict定義,即4res = requests.post(url, data=data, headers=headers, auth=(’tv2’, sign))##post請求,且認(rèn)證user=‘tv2’,password=‘sign’print res.text##就能看到打印結(jié)果了。
相關(guān)文章:
1. java - C語言算法題-韓信點(diǎn)兵 求解?2. html5 - 微信瀏覽器視頻播放失敗3. java - spring-data Jpa 不需要執(zhí)行save 語句,Set字段就可以自動執(zhí)行保存的方法?求解4. javascript - 這問題怎么處理額5. 網(wǎng)頁爬蟲 - Python 爬蟲中如何處理驗(yàn)證碼?6. javascript - jQuery中l(wèi)ive事件在移動微信端下沒有效果;代碼如下7. javascript - SuperSlide.js火狐不兼容怎么回事呢8. javascript - owl.carousel.js這個插件的原作者的網(wǎng)址是多少了?9. phpstady在win10上運(yùn)行10. 在應(yīng)用配置文件 app.php 中找不到’route_check_cache’配置項(xiàng)
