python第一个爬虫。

Posted gsd-tt

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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)

运行结果如下:

技术图片

技术图片

 

以上是关于python第一个爬虫。的主要内容,如果未能解决你的问题,请参考以下文章

scrapy主动退出爬虫的代码片段(python3)

引点科技私房菜专栏之第一个Python小爬虫

用python零基础写爬虫--编写第一个网络爬虫

第一个爬虫代码

Python入门到精通精品第十章 - 爬虫

python第一个爬虫。