#!/user/bin/env python
#coding=utf-8
import requests
import datetime
import time
import threading
class url_request():
times = []
error = []
def req(self,AppID,url):
myreq=url_request()
headers = {'User-Agent' : 'Mozilla/5.0 (Linux; Android 4.2.1; en-us; Nexus 4 Build/JOP40D) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1025.166 Mobile Safari/535.19'}
payload = {'AppID':AppID,'CurrentURL':url}
r = requests.post("http://xx.xxx.com/WeiXinJSAccessToken/json/WeChatJSTicket",headers=headers,data=https://bbs.csdn.net/topics/payload)
ResponseTime=float(r.elapsed.microseconds)/1000 #獲取回應時間,單位ms
myreq.times.append(ResponseTime) #將回應時間寫入陣列
if r.status_code !=200 :
myreq.error.append("0")
if __name__=='__main__':
myreq=url_request()
threads = []
starttime = datetime.datetime.now()
print "request start time %s" %starttime
nub = 50#設定并發執行緒數
ThinkTime = 0.5#設定思考時間
for i in range(1, nub+1):
t = threading.Thread(target=myreq.req, args=('12','http://m.ctrip.com/webapp/cpage/#mypoints'))
threads.append(t)
for t in threads:
time.sleep(ThinkTime)
#print "thread %s" %t #列印執行緒
t.setDaemon(True)
t.start()
t.join()
endtime = datetime.datetime.now()
print "request end time %s" %endtime
time.sleep(3)
AverageTime = "{:.3f}".format(float(sum(myreq.times))/float(len(myreq.times))) #計算陣列的平均值,保留3位小數
print "Average Response Time %s ms" %AverageTime #列印平均回應時間
usetime = str(endtime - starttime)
hour = usetime.split(':').pop(0)
minute = usetime.split(':').pop(1)
second = usetime.split(':').pop(2)
totaltime = float(hour)*60*60 + float(minute)*60 + float(second) #計算總的思考時間+請求時間
print "Concurrent processing %s" %nub #列印并發數
print "use total time %s s" %(totaltime-float(nub*ThinkTime)) #列印總共消耗的時間
print "fail request %s" %myreq.error.count("0") #列印錯誤請求數
復制代碼
復制代碼
request start time 2015-02-10 18:24:14.316000
request end time 2015-02-10 18:24:39.769000
Average Response Time 46.700 ms
Concurrent processing 50
use total time 25.453 s
fail request 1
uj5u.com熱心網友回復:
就是簡單的多執行緒uj5u.com熱心網友回復:
我知道 我這邊的話要修改里面的資料成我們公司的介面資料 不知道怎么修改 麻煩大佬指教一下uj5u.com熱心網友回復:
這個視情況而定,如果想簡單點的話,調整一下url,header,payload引數就差不多了,
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/33156.html
上一篇:Python獲取CATIA坐標值
下一篇:Python類的問題
