python第一个爬虫。
1、测试羽毛球规则程序代码。
原代码如下:
from random import random
print("学号尾数08")
def printIntro():
print("这个程序模拟两个选手A和B的羽毛球竞技比赛")
print("程序运行需要A和B的能力值(以0到1之间的小数表示)")
def getInputs():
a = eval(input("请输入选手A的能力值(0-1): "))
b = eval(input("请输入选手B的能力值(0-1): "))
n = eval(input("模拟比赛的场次: "))
m = eval(input("模拟次数:"))
return a, b, n, m
def simNGames(n, probA, probB):
winsA, winsB = 0, 0
scoreA_ls=[]
scoreB_ls=[]
for i in range(n):
scoreA, scoreB = simOneGame(probA, probB)
scoreA_ls.append(scoreA)
scoreB_ls.append(scoreB)
if scoreA > scoreB:
winsA += 1
else:
winsB += 1
return winsA, winsB,scoreA_ls,scoreB_ls
def gameOver(a,b):
if(a>20 or b>20):
if(abs(a-b)>=2 and a<=29 and b<=29):
return True
else:
return a==30 or b==30
else:
return False
def simOneGame(probA, probB):
scoreA, scoreB = 0, 0
serving = "A"
while not gameOver(scoreA, scoreB):
if serving == "A":
if random() < probA:
scoreA += 1
else:
serving="B"
else:
if random() < probB:
scoreB += 1
else:
serving="A"
return scoreA, scoreB
def printSummary(winsA, winsB,m,scoreA_ls,scoreB_ls):
n = winsA + winsB
print("模型模拟次数{}".format(m))
print("竞技分析开始,共模拟{}场比赛".format(n))
print("A选手各场次得分比分:")
print(scoreA_ls)
print("B选手各场次得分比分:")
print(scoreB_ls)
print("选手A获胜{}场比赛,占比{:0.1%}".format(winsA, winsA/n))
print("选手B获胜{}场比赛,占比{:0.1%}".format(winsB, winsB/n))
def main():
printIntro()
probA, probB, n, m= getInputs()
for i in range(m):
winsA, winsB,scoreA_ls,scoreB_ls = simNGames(n, probA, probB)
printSummary(winsA, winsB,m,scoreA_ls,scoreB_ls)
main()
加了测试函数的代码如下:
from random import random
print("学号尾数08")
def printIntro():
print("这个程序模拟两个选手A和B的羽毛球竞技比赛")
print("程序运行需要A和B的能力值(以0到1之间的小数表示)")
try:
printIntro(x)
except:
print('printIntro error')
def getInputs():
a = eval(input("请输入选手A的能力值(0-1): "))
b = eval(input("请输入选手B的能力值(0-1): "))
n = eval(input("模拟比赛的场次: "))
m = eval(input("模拟次数:"))
return a, b, n, m
try:
getInputs(x)
except:
print('getInputs error')
def simNGames(n, probA, probB):
winsA, winsB = 0, 0
scoreA_ls=[]
scoreB_ls=[]
for i in range(n):
scoreA, scoreB = simOneGame(probA, probB)
scoreA_ls.append(scoreA)
scoreB_ls.append(scoreB)
if scoreA > scoreB:
winsA += 1
else:
winsB += 1
return winsA, winsB,scoreA_ls,scoreB_ls
try:
simNGames(1000,0.1)
except:
print('simNgame error')
def gameOver(a,b):
if(a>20 or b>20):
if(abs(a-b)>=2 and a<=29 and b<=29):
return True
else:
return a==30 or b==30
else:
return False
try:
gameover(1,20)
except:
print('gameOver error')
def simOneGame(probA, probB):
scoreA, scoreB = 0, 0
serving = "A"
while not gameOver(scoreA, scoreB):
if serving == "A":
if random() < probA:
scoreA += 1
else:
serving="B"
else:
if random() < probB:
scoreB += 1
else:
serving="A"
return scoreA, scoreB
try:
simOneGame(0.1)
except:
print('SimOneGame error')
def printSummary(winsA, winsB,m,scoreA_ls,scoreB_ls):
n = winsA + winsB
print("模型模拟次数{}".format(m))
print("竞技分析开始,共模拟{}场比赛".format(n))
print("A选手各场次得分比分:")
print(scoreA_ls)
print("B选手各场次得分比分:")
print(scoreB_ls)
print("选手A获胜{}场比赛,占比{:0.1%}".format(winsA, winsA/n))
print("选手B获胜{}场比赛,占比{:0.1%}".format(winsB, winsB/n))
try:
printSummary(500)
except:
('printSummary error')
def main():
printIntro()
probA, probB, n, m= getInputs()
for i in range(m):
winsA, winsB,scoreA_ls,scoreB_ls = simNGames(n, probA, probB)
printSummary(winsA, winsB,m,scoreA_ls,scoreB_ls)
main()
为了测试显得更有价值,所以将原代码中许多函数改成错误的。运行结果如下:

2、python连接360主页20次:
代码如下:
# -*- coding: utf-8 -*-
"""
Created on Wed May 22 21:59:28 2019
@author: 小米
"""
import requests
def getHTMLText(url):
try:
r=requests.get(url,timeout=30)
r.raise_for_status()
r.encoding='utf-8'
return r.text
except:
return "dddd"
url="https://hao.360.cn/"
print(getHTMLText(url))
for i in range(20):
getHTMLText(url)
print(i+1)
运行结果如下:



浙公网安备 33010602011771号