python爬取廖雪峰的python3教程

#coding:utf-8
import requests
from bs4 import BeautifulSoup
import lxml
import codecs
import sys
reload(sys)
sys.setdefaultencoding('utf-8')

#得到所有页面的url
def get_url(url):
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36'}
    request = requests.get(url, headers=headers)
    html = request.text
    all_url = []
    soup = BeautifulSoup(html, 'lxml')
    all_a = soup.find('div', class_='x-sidebar-left-content').find_all('a')
    for a in all_a:
        all_url.append('http://www.liaoxuefeng.com' + a.get('href'))
    return all_url

#下载
def download_text(all_url):
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36'}
    for url in all_url:   #浏览每一个页面,然后下载
        re=requests.get(url,headers=headers)
        html=re.text
        soup=BeautifulSoup(html,'lxml')
        all_h4=soup.find_all('h4')
        div=soup.find('div',class_='x-wiki-content')
        content=all_h4[0].text+div.text
        if all_h4[0].text=='map/reduce':   #这是判断里面的名字可能和路径相冲突
            filename='g:\\file\\'+'map and reduce'+'.py'
        elif all_h4[0].text==u'TCP/IP简介':
            filename='g:\\file\\'+'TCP and IP'+'.py'
        elif all_h4[0].text=='async/await':
            filename='g:\\file\\'+'async and await'+'.py'
        else:
            filename='g:\\file\\'+all_h4[0].text+'.py'
            print all_h4[0].text
        print u'正在下载'+all_h4[0].text
        with codecs.open(filename,'w',encoding='utf-8') as f:   #将信息写入py文件中
            f.write(content)

if __name__=="__main__":
    url = 'http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000'
    all_url=get_url(url)
    download_text(all_url)

Python是一种计算机程序设计语言。你可能已经听说过很多种流行的编程语言,比如非常难学的C语言,非常流行的Java语言,适合初学者的Basic语言,适合网页编程的JavaScript语言等等。 那Python是一种什么语言? 首先,我们普及一下编程语言的基础知识。用任何编程语言来开发程序,都是为了让计算机干活,比如下载一个MP3,编写一个文档等等,而计算机干活的CPU只认识机器指令,所以,尽管不同的编程语言差异极大,最后都得“翻译”成CPU可以执行的机器指令。而不同的编程语言,干同一个活,编写的代码量,差距也很大。 比如,完成同一个任务,C语言要写1000行代码,Java只需要写100行,而Python可能只要20行。 所以Python是一种相当高级的语言。 你也许会问,代码少还不好?代码少的代价是运行速度慢,C程序运行1秒钟,Java程序可能需要2秒,而Python程序可能就需要10秒。 那是不是越低级的程序越难学,越高级的程序越简单?表面上来说,是的,但是,在非常高的抽象计算中,高级的Python程序设计也是非常难学的,所以,高级程序语言不等于简单。 但是,对于初学者和完成普通任务,Python语言是非常简单易用的。连Google都在大规模使用Python,你就不用担心学了会没用。 用Python可以做什么?可以做日常任务,比如自动备份你的MP3;可以做网站,很多著名的网站包括YouTube就是Python写的;可以做网络游戏的后台,很多在线游戏的后台都是Python开发的。总之就是能干很多很多事啦。 Python当然也有不能干的事情,比如写操作系统,这个只能用C语言写;写手机应用,只能用Swift/Objective-C(针对iPhone)和Java(针对Android);写3D游戏,最好用C或C++。 如果你是小白用户,满足以下条件: 会使用电脑,但从来没写过程序; 还记得初中数学学的方程式和一点点代数知识; 想从编程小白变成专业的软件架构师; 每天能抽出半个小时学习。 不要再犹豫了,这个教程就是为你准备的! 准备好了吗?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不才陈某

欢迎关注公众号【码猿技术专栏】

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值