实用文档
.
Python总结
目录
Python总结.....................................................................................................................1
前言.............................................................................................................................2
〔一〕如何学习Python.........................................................................................2
〔二〕一些Python免费课程推荐.......................................................................4
〔三〕Python爬虫需要哪些知识?....................................................................5
〔四〕Python爬虫进阶.........................................................................................8
〔五〕Python爬虫面试指南..............................................................................11
〔六〕推荐一些不错的Python博客.................................................................13
〔七〕Python如何进阶.......................................................................................14
〔八〕Python爬虫入门.......................................................................................16
〔九〕Python开发微信公众号..........................................................................20
〔十〕Python面试概念和代码..........................................................................24
〔十一〕Python书籍...........................................................................................34
实用文档
.
前言
知乎:路人甲
微博:玩数据的路人甲
微信公众号:一个程序员的日常
在知乎分享已经有一年多了,之前一直有朋友说我的答复能整理成书籍了,一直
偷懒没做,最近有空仔细整理了知乎上的答复和文章另外也添加了一些新的内
容,完成了几本小小的电子书,这一本是有关于Python方面的。
还有另外几本包括我的一些数据分析方面的读书笔记、增长黑客的读书笔记、机
器学习十大算法等等内容。将会在我的微信公众号:一个程序员的日常进行更新,
同时也可以关注我的知乎账号:路人甲及时关注我的最新分享用数据讲故事。
〔一〕如何学习Python
学习Python大致可以分为以下几个阶段:
1.刚上手的时候肯定是先过一遍Python最根本的知识,比方说:变量、数据结
构、语法等,根底过的很快,根本上1~2周时间就能过完了,我当时是在这儿
看的根底:Python简介|菜鸟教程
实用文档
.
2.看完根底后,就是做一些小工程稳固根底,比方说:做一个终端计算器,如果
实在找不到什么练手工程,可以在Codecademy-learntocode,
interactively,forfree上面进行练习。
3.如果时间充裕的话可以买一本讲Python根底的书籍比方【Python编程】,
阅读这些书籍,在稳固一遍根底的同时你会发现自己诸多没有学习到的边边角
角,这一步是对自己根底知识的补充。
库是Python的精华所在,可以说Python库组成并且造就了Python,
Python库是Python开发者的利器,所以学习Python库就显得尤为重要:The
PythonStandardLibrary,Python库很多,如果你没有时间全部看完,不妨
学习一遍常用的Python库:Python常用库整理-知乎专栏
库是开发者利器,用这些库你可以做很多很多东西,最常见的网络爬
虫、自然语言处理、图像识别等等,这些领域都有很强大的Python库做支持,
所以当你学了Python库之后,一定要第一时间进行练习。如何寻找自己需要的
Python库呢?推荐我之前的一个答复:如何找到适合需求的Python库?
实用文档
.
6.学习使用了这些Python库,此时的你应该是对Python十分满意,也十分冲
动能遇到这样的语言,就是这个时候不妨开始学习Python数据结构与算法,
Python设计模式,这是你进一步学习的一个重要步骤:faif/python-patterns
7.当度过艰难的第六步,此时选择你要研究的方向,如果你想做后端开发,不妨
研究研究Django,再往后,就是你自己自由发挥了。
〔二〕一些Python免费课程推荐
以下课程都为免费课程
零根底相关
适用人群:Python零根底的初学者、Web开发程序员、运维人员、有志于从事
互联网行业以及各领域应用Python的人群
➢疯狂的Python:快速入门精讲
➢零根底入门学习Python
➢玩转Python语言
➢Python语言程序设计
➢程序设计入门
➢可汗学院公开课:计算机科学
➢python入门到精通
实用文档
.
➢Python交互式编程入门的课程主页
➢Python交互编程入门〔第2局部〕的课程主页
web方向
PythonDjango快速Web应用开发入门
爬虫
Python实战:一周学会爬取网页
数据分析方向
数据分析实战根底课程
〔三〕Python爬虫需要哪些知识?
要学会使用Python爬取网页信息无外乎以下几点内容:
1、要会Python
2、知道网页信息如何呈现
3、了解网页信息如何产生
4、学会如何提取网页信息
第一步Python是工具,所以你必须熟练掌握它,要掌握到什么程度呢?如果你
只想写一写简单的爬虫,不要炫技不考虑爬虫效率,你只需要掌握:
实用文档
.
➢数据类型和变量
➢字符串和编码
➢使用list和tuple
➢条件判断、循环
➢使用dict和t
你甚至不需要掌握函数、异步、多线程、多进程,当然如果想要提高自己小爬虫
的爬虫效率,提高数据的精确性,那么记住最好的方式是去系统的学习一遍
Python,去哪儿学习?Python教程
假设已经熟悉了最根底的Python知识,那么进入第二步:知道网页信息如何呈
现?你首先要知道所需要抓取的数据是怎样的呈现的,就像是你要学做一幅画,
在开始之前你要知道这幅画是用什么画出来的,铅笔还是水彩笔...可能种类是多
样的,但是放到网页信息来说这儿只有两种呈现方式:
1、HTML〔HTML简介〕
2、JSON〔JSON简介〕
HTML是用来描述网页的一种语言
JSON是一种轻量级的数据交换格式
假设你现在知道了数据是由HTML和JSON呈现出来的,那么我们紧接着第三
步:数据怎么来?数据当然是从效劳器反响给你的,为什么要反响给你?因为你
发出了请求。
实用文档
.
“Hi~,效劳器我要这个资源〞
“正在传输中...〞
“已经收到HTML或者JSON格式的数据〞
这个请求是什么请求?要搞清楚这一点你需要了解一下的根底知识,更加精
确来说你需要去了解GET和POST是什么,区别是什么。也许你可以看看这个:
浅谈中Get与Post的区别-hyddd-博客园
很快乐你使用的是Python,那么你只需要去掌握好快速上手-Requests2.10.0
文档,requests可以帮你模拟发出GET和POST请求,这真是太棒了。
饭菜已经备好,两菜一汤美味佳肴,下面就是好好享受了。现在我们已经拿到了
数据,我们需要在这些错乱的数据中提取我们需要的数据,这时候我们有两个选
择。
第一招:万能钥匙
Python正那么表达式指南,再大再乱的内容,哪怕是大海捞针,只要告诉我
这个针的样子我都能从茫茫大海中捞出来,强大的正那么表达式是你提取数据的
不二之选。
第二招:笑里藏刀
BeautifulSoup4.2.0文档,或许我们有更好的选择,我们把原始数据和我们想
要的数据的样子扔个这个Beautifulsoup,然后让它帮我们去寻找,这也是一个
不错的方案,但是论灵活性,第二招还是略逊于第一招。
实用文档
.
第三招:双剑合璧
最厉害的招式莫过于结合第一招和第二招了,打破天下无敌手。
根底知识我都会,可是我还是写不了一个爬虫啊!
客观别急,这还没完。
以下这些工程,你拿来学习学习练练手。
一些教学工程你值得拥有:
➢03.豆瓣电影TOP250
➢04.另一种抓取方式
还不够?这儿有很多:
➢知乎--你需要这些:Python3.x爬虫学习资料整理
➢如何学习Python爬虫[入门篇]?-知乎专栏
➢知乎--Python学习路径及练手工程合集
〔四〕Python爬虫进阶
爬虫无非分为这几块:分析目标、下载页面、解析页面、存储内容,其中下载页
面不提。
实用文档
.
1.分析目标
所谓分析就是首先你要知道你需要抓取的数据来自哪里?怎么来?普通的网站
一个简单的POST或者GET请求,不加密不反爬,几行代码就能模拟出来,这
是最根本的,进阶就是学会分析一些复杂的目标,比方说:淘宝、新浪微博登陆
以及网易云的评论信息等等。
2.解析页面
解析页面主要是选择什么库或者那些库结合能使解析速度更快,可能你一开始你
通过种种地方了解到了bs库,于是你对这个库很痴迷,以后只要写爬虫,总是
先写上:
importrequests
frombs4importBeautifulSoup
当然bs已经很优秀了,但是并不代表可以用正那么表达式解析的页面还需要使
用bs,也不代表使用lxml能解决的还要动用bs,所以这些解析库的速度是你
在进阶时要考虑的问题。
3.存储内容
刚开始学爬虫,一般爬取的结果只是打印出来,最后把在终端输出的结果复制粘
贴保存就好了;后来发现麻烦会用上xlwt/openpyxl/csv的把存储内容写入表
实用文档
.
格,再后来使用数据库sqlite/mysql/neo4j只要调用了库都很简单,当然这是
入门。
进阶要开始学习如何选择适宜的数据库,或者存储方式。当爬取的内容过千万的
时候,如何设计使存储速度更快,比方说当既有人物关系又有人物关系的时候,
一定会用neo4j来存储关系,myslq用来存储用户信息,这样分开是因为如果
信息全部存入neo4j,后期的存储速度经十分的慢。
当你每个步骤都能做到很优秀的时候,你应该考虑如何组合这四个步骤,使你的
爬虫到达效率最高,也就是所谓的爬虫策略问题,爬虫策略学习不是一朝一夕的
事情,建议多看看一些比拟优秀的爬虫的设计方案,比方说Scrapy。
除了爬取策略以外,还有几点也是必备的:
1.代理策略以及多用户策略
代理是爬虫进阶阶段必备的技能,与入门阶段直接套用代理不同,在进阶阶段你
需要考虑如何设计使用代理策略,什么时候换代理,代理的作用范围等等,多用
户的抓取策略考虑的问题根本上与代理策略相同。
2.增量式抓取以及数据刷新
比方说你抓取的是一个酒店网站关于酒店价格数据信息的,那么会有这些问题:
酒店的房型的价格是每天变动的,酒店网站每天会新增一批酒店,那么如何进行
存储、如何进行数据刷新都是应该考虑的问题。
3.验证码相关的一些问题
实用文档
.
有很多人提到验证码,我个人认为验证码不是爬虫主要去解决的问题,验证码不
多的情况考虑下载到本地自己输入验证码,在多的情况下考虑接入打码平台。
〔五〕Python爬虫面试指南
前段时间快要毕业,而我又不想找自己的老本行Java开发了,所以面了很多
Python爬虫岗位。因为我在南京上学,所以我一开始只是在南京投了简历,我
一共面试了十几家企业,其中只有一家没有给我发offer,其他企业都愿意给到
10K的薪资,不要拿南京的薪资水平和北上深的薪资水平比拟,结合面试常问的
问题类型说一说我的心得体会。
第一点:Python
因为面试的是Python爬虫岗位,面试官大多数会考察面试者的根底的Python
知识,包括但不限于:
➢Python2.x与Python3.x的区别
➢Python的装饰器
➢Python的异步
➢Python的一些常用内置库,比方多线程之类的
实用文档
.
第二点:数据结构与算法
数据结构与算法是对面试者尤其是校招生面试的一个很重要的点,当然小公司不
会太在意这些,从目前的招聘情况来看对面试者的数据结构与算法的重视程度与
企业的好坏成正比,那些从不问你数据结构的你就要留神他们是否把你当码农用
的,当然以上情况不绝对,最终解释权归面试官所有。
第三点:Python爬虫
最重要也是最关键的一点当然是你的Python爬虫相关的知识与经验储藏,这通
常也是面试官考察的重点,包括但不限于:
➢你遇到过的反爬虫的策略有哪些?
➢你常用的反反爬虫的方案有哪些?
➢你用过多线程和异步吗?除此之外你还用过什么方法来提高爬虫效率?
➢有没有做过增量式抓取?
➢对Python爬虫框架是否有了解?
第四点:爬虫相关的工程经验
爬虫重在实践,除了理论知识之外,面试官也会十分注重爬虫相关的工程:
➢你做过哪些爬虫工程?如果有Github最好
实用文档
.
➢你认为你做的最好的爬虫工程是哪个?其中解决了什么难题?有什么特
别之处?
以上是我在面试过程中,会碰到的一些技术相关的问题的总结,当然面试中不光
是技术这一点,但是对于做技术的,过了技术面根本上就是薪资问题了。
〔六〕推荐一些不错的Python博客
如果是Python根底的话,廖雪峰的博客教程会是一个不错的选择:
➢Python3教程
➢Python2.7教程
当然很多刚接触Python的同学反响廖大大的教程中局部跳跃性太大,如果觉得
跳跃性太大可以结合菜鸟教程一起看:
➢Python3教程|菜鸟教程
➢Python根底教程|菜鸟教程
如果你英文稍好的话推荐还是看官方文档:Python3.6.0documentation
实用文档
.
如果不是为了学习Python根底的话,推荐几个其他的博客。
➢董老师的博客:小明明sàdomicile【Python-Web开发实战】的作者,
➢知乎某位工程师的博客:分类【Python】,具体是哪位大神我不太清楚。
➢依云大大的博客文章值得深读:依云'sBlog
➢【从Python开始学编程】的作者博客:Python-标签-Vamei-博客
园,但是此博客的内容也是比拟偏向根底知识的。
➢pythonware的创造者,Python图像库〔PIL〕的创造者:
➢我很喜欢的一位作者,Pyhub创始人:Yusheng'sTechBlog
➢xlzd杂谈文章不是很多,有兴趣可以多看看在知乎的他。
➢twelfthing-博客园
➢Python|the5fire的技术博客
〔七〕Python如何进阶
很多人在学习编程之初都会碰到这种问题:学会了根底的语法了,但是还是做不
了工程,不知道如何下手。
当初,我学习C的时候是这样、Java的时候是这样、Python的时候也是这样,
其实不管什么语言、什么知识都是这样:理论根底知识-能动手做工程是有一
道鸿沟的。
实用文档
.
那么如何突破这条鸿沟?中间的桥梁是什么?
其实题主自己已经答复出来了:照抄!
所谓照抄前提是有样本。
首先找到一些简单易上手的工程,这些工程大多散落在Python实践相关的书籍
中、Github上,这些实战工程知乎上都有很多推荐。
1.一些比拟好的适合初学者动手的工程:
➢Show-Me-the-Code/show-me-the-code
➢aosabook/500lines
另外知乎上这个问题下的一些推荐的工程还是非常适合新手练习的,可以作为参
考:Python的练手工程有哪些值得推荐?
2.大多数的Python书里面〔除了纯理论书〕都是有小工程的,而且书的一个优
点是它会一步一步解释这样做的原因。
先照抄这些工程,实现这些小功能在电脑上能运行确认无误之后,回过头来看代
码:
➢有没有你不理解的地方,不理解的地方标记去搜索引擎或者书中找解释。
实用文档
.
➢学习作者设计这个工程的思路方法,并运用到接下来的工程,如果时间充
裕,建议隔天再重新再不看书的情况下重新自己实现一遍这些小工程。
如果你是跟着实战的书敲代码的,很多时候工程都不会一遍运行成功,那么你就
要根据各种报错去寻找原因,这也是一个学习的过程。
总结起来从Python入门跳出来的过程分为三步:照抄、照抄之后的理解、重新
自己实现。
〔八〕Python爬虫入门
想写这么一篇文章,但是知乎社区爬虫大神很多,光是整理他们的答案就够我这
篇文章的内容了。对于我个人来说我更喜欢那种非常实用的教程,这种教程对于
想直接上手爬虫做一些小东西的朋友来说是极好的。
用一个精彩的答复作为开头:如何入门Python爬虫?-谢科的答复
如果你想学习编程,但是找不到学习路径和资源,欢送关注专栏:学习编程
第一:Python爬虫学习系列教程
Python版本:2.7
整体目录:
一、爬虫入门
实用文档
.
➢Python爬虫入门一之综述
➢Python爬虫入门二之爬虫根底了解
➢Python爬虫入门三之Urllib库的根本使用
➢Python爬虫入门四之Urllib库的高级用法
➢Python爬虫入门五之URLError异常处理
➢Python爬虫入门六之Cookie的使用
➢Python爬虫入门七之正那么表达式
二、爬虫实战
➢Python爬虫实战一之爬取糗事百科段子
➢Python爬虫实战二之爬取百度贴吧帖子
➢Python爬虫实战三之实现山东大学无线网络掉线自动重连
➢Python爬虫实战四之抓取淘宝MM照片
➢Python爬虫实战五之模拟登录淘宝并获取所有订单
➢Python爬虫实战六之抓取爱问知识人问题并保存至数据库
➢Python爬虫实战七之计算大学本学期绩点
➢Python爬虫实战八之利用Selenium抓取淘宝匿名旺旺
三、爬虫利器
➢Python爬虫利器一之Requests库的用法
➢Python爬虫利器二之BeautifulSoup的用法
➢Python爬虫利器三之Xpath语法与lxml库的用法
实用文档
.
➢Python爬虫利器四之PhantomJS的用法
➢Python爬虫利器五之Selenium的用法
➢Python爬虫利器六之PyQuery的用法
四、爬虫进阶
➢Python爬虫进阶一之爬虫框架概述
➢Python爬虫进阶二之PySpider框架安装配置
➢Python爬虫进阶三之爬虫框架Scrapy安装配置
➢Python爬虫进阶四之PySpider的用法
第二〔第一的姊妹篇〕:Python爬虫入门教程
Python版本:2.7
教程目录:
➢[Python]网络爬虫〔一〕:抓取网页的含义和URL根本构成
➢[Python]网络爬虫〔二〕:利用urllib2通过指定的URL抓取网页内容
➢[Python]网络爬虫〔三〕:异常的处理和状态码的分类
➢[Python]网络爬虫〔四〕:Opener与Handler的介绍和实例应用
➢[Python]网络爬虫〔五〕:urllib2的使用细节与抓站技巧
➢[Python]网络爬虫〔六〕:一个简单的百度贴吧的小爬虫
➢[Python]网络爬虫〔七〕:Python中的正那么表达式教程
➢[Python]网络爬虫〔八〕:糗事百科的网络爬虫〔v0.3〕源码及解析(简化更
实用文档
.
新)
➢[Python]网络爬虫〔九〕:百度贴吧的网络爬虫〔v0.4〕源码及解析
➢[Python]网络爬虫〔十〕:一个爬虫的诞生全过程〔以山东大学绩点运算为
例〕
➢[Python]网络爬虫〔11〕:亮剑!爬虫框架小抓抓Scrapy闪亮登场!
➢[Python]网络爬虫〔12〕:爬虫框架Scrapy的第一个爬虫例如入门教程
第三:你已经看完上面〔第一或者第二〕的教程:再推荐知乎用户@陈唯源的
实战练习博客
➢Python爬虫学习记录〔1〕——Xiami全站播放数
➢Python爬虫学习记录〔2〕——LDA处理歌词
➢百度音乐带标签,作曲,演唱者,类别的歌词数据
➢Python爬虫学习记录〔4〕——传说中的足彩倍投法。。好似也不是那么靠
谱
➢2021~2021.5全球所有足球比赛比分数据以及足彩各公司盘口
➢Python爬虫学习记录〔3〕——用Python获取虾米加心歌曲,并获取MP3
下载地址
➢Python爬虫学习记录〔5〕——pythonmongodb+爬虫+的
acfun视频排行榜
➢Python爬虫学习记录〔0〕——Python爬虫抓站记录〔虾米,百度,豆
瓣,新浪微博〕
实用文档
.
第四:最后推荐知乎用户@gagasalamer的实战练习博客
➢爬虫教程〔1〕根底入门
➢爬虫教程〔2〕性能进阶
➢知乎用户信息爬虫〔规模化爬取〕
➢用scrapy爬取豆瓣电影新片榜
➢用scrapy对豆瓣top250页面爬取〔多页面爬取〕
➢用scrapy自动爬取下载图片
➢用scrapy自动下载石原sama的豆瓣影人图集(727张图片,自动下载〕
希望以上的教程可以帮助到大家。
〔九〕Python开发微信公众号
我的第一个Python工程就是做的微信公众号机器人,按照当时我的思路来讲讲
如何学习使用Python来开发微信公众号:大家伙收藏顺手点个赞呗。
微信公众号功能开发分为两大块:需要调用微信内部功能、不需要调用微信内部
功能,重点在调用微信内部功能组建。
1、需要调用微信内部功能
实用文档
.
需要调用微信内部功能组件的比方:公众号收发消息|图片、页面分享至朋友圈、
用户授权提取用户根本信息、微信小店、微信公众号菜单等内部功能组件,这些
功能组件在微信公众号开发者文档里面找到:微信公众平台开发者文档
对于这些功能组件,开发者文档都提供了详细的接口文档,告诉你如何调用,而
你只需要用Python调用这些接口即可。比方一个很简单的消息发送的方法如
下:
实用文档
.
当然在这所有的调用之前,需要进行一些授权验证,同样开发者文档有一套完整
的接入指南:接入指南-微信公众平台开发者文档
很遗憾很多初学者在一开始看这份文档的时候并不能看懂,所以这里也推荐一些
我以前学习摸索的过程中使用到的一些简单易学的教程。
你可以先做一个简单的微信机器人练练手〔零根底十分容易上手〕:
➢使用python一步一步搭建微信公众平台〔一〕
➢使用python一步一步搭建微信公众平台〔二〕----搭建一个中英互译的
翻译工具
实用文档
.
➢使用python一步一步搭建微信公众平台〔三〕----添加用户关注后的欢
送信息与听音乐功能
➢使用python一步一步搭建微信公众平台〔四〕----将小黄鸡引入微信自
动回复
➢使用python一步一步搭建微信公众平台〔五〕----使用mysql效劳来记
录用户的反响
如果你已经能按照以上的教程搭建一个完整的微信机器人了,根本上对于微信收
发消息等等简单功能已经没有什么障碍了。下面再继续学习如下教程,开始学习
如何调用其他一些相对来说比拟复杂的接口。
➢微信公众平台开发入门教程
➢微信公众平台开发—天气预报
➢微信公众平台开发—小黄鸡
➢微信公众平台开发—人脸识别
➢微信公众平台开发—百度地图
➢微信公众平台开发—笑话
➢微信公众平台开发—在线点歌
➢微信公众平台开发—附近查询
➢微信公众平台开发—快递物流
➢微信公众平台开发—一键关注
实用文档
.
当你实验了如上的教程之后,相信官方文档的所有接口调用对你来说已经小菜一
碟了。
2、不需要调用微信内部功能
不需要调用微信内部功能组件的,就如同正常的web页面一样,比方填写表单
进行进行注册、点击按钮进行跳转等等,这些都是正常的web请求,按照正常
的web开发方法走即可。
〔十〕Python面试概念和代码
〔一〕、这两个参数是什么意思:*args,**kwargs?我们为什么要使用它们?
实用文档
.
答:如果我们不确定往一个函数中传入多少参数,或者我们希望以元组〔tuple〕
或者列表〔list〕的形式传参数的时候,我们可以使用*args〔单星号〕。如果我
们不知道往函数中传递多少个关键词参数或者想传入字典的值作为关键词参数
的时候我们可以使用**kwargs〔双星号〕,args、kwargs两个标识符是约定俗
成的用法。
另一种答法:当函数的参数前面有一个星号*号的时候表示这是一个可变的位置
参数,两个星号**表示这个是一个可变的关键词参数。星号*把序列或者集合解
包〔unpack〕成位置参数,两个星号**把字典解包成关键词参数。
〔二〕、谈一谈Python的装饰器〔decorator〕
装饰器本质上是一个Python函数,它可以让其它函数在不作任何变动的情况下
增加额外功能,装饰器的返回值也是一个函数对象。它经常用于有切面需求的场
实用文档
.
景。比方:插入日志、性能测试、事务处理、缓存、权限校验等。有了装饰器我
们就可以抽离出大量的与函数功能无关的雷同代码进行重用。
有关于具体的装饰器的用法看这里:装饰器-廖雪峰的官方网站
〔三〕、简要描述Python的垃圾回收机制〔garbagecollection〕
Python中的垃圾回收是以引用计数为主,标记-去除和分代收集为辅。
引用计数:Python在内存中存储每个对象的引用计数,如果计数变成0,该对
象就会消失,分配给该对象的内存就会释放出来。
实用文档
.
标记-去除:一些容器对象,比方list、dict、tuple,instance等可能会出现引
用循环,对于这些循环,垃圾回收器会定时回收这些循环〔对象之间通过引用〔指
针〕连在一起,构成一个有向图,对象构成这个有向图的节点,而引用关系构成
这个有向图的边〕。
分代收集:Python把内存根据对象存活时间划分为三代,对象创立之后,垃圾
回收器会分配它们所属的代。每个对象都会被分配一个代,而被分配更年轻的代
是被优先处理的,因此越晚创立的对象越容易被回收。
如果你想要深入了解Python的GC机制,点击这里:[转载]Python垃圾回收机
制--完美讲解!
〔四〕、Python多线程〔multi-threading〕。这是个好主意吗?
Python并不支持真正意义上的多线程,Python提供了多线程包。Python中有
一个叫GlobalInterpreterLock〔GIL〕的东西,它能确保你的代码中永远只有
一个线程在执行。经过GIL的处理,会增加执行的开销。这就意味着如果你先要
提高代码执行效率,使用threading不是一个明智的选择,当然如果你的代码
是IO密集型,多线程可以明显提高效率,相反如果你的代码是CPU密集型的
这种情况下多线程大局部是鸡肋。
想要深入详细了解多线程,点击这里:详解Python中的多线程编程_python
想了解一下IO密集和CPU密集可以点击这里:CPU-bound(计算密集型)和I/O
bound(I/O密集型)
实用文档
.
〔五〕、说明os,sys模块不同,并列举常用的模块方法?
官方文档:
os模板提供了一种方便的使用操作系统函数的方法
sys模板可供访问由解释器使用或维护的变量和与解释器交互的函数
另一种答复:
os模块负责程序与操作系统的交互,提供了访问操作系统底层的接口。sys模块
负责程序与Python解释器的交互,提供了一系列的函数和变量用户操作
Python运行时的环境。一些常用的方法:
实用文档
.
一些常用的用法例如:
实用文档
.
想要了解更详细的使用请访问:os和sys模块-君醉
〔六〕、什么是lambda表达式?它有什么好处?
简单来说,lambda表达式通常是当你需要使用一个函数,但是又不想费脑袋去
命名一个函数的时候使用,也就是通常所说的匿名函数。
lambda表达式一般的形式是:关键词lambda后面紧接一个或多个参数,紧接
一个冒号“:〞,紧接一个表达式。lambda表达式是一个表达式不是一个语句。
实用文档
.
想更加详细的了解Python中的Lamdba表达式可以点击这里:Lambda表达
式有何用处?如何使用?-Python
〔七〕、Python中pass语句的作用是什么?
pass语句不会执行任何操作,一般作为占位符或者创立占位程序
〔八〕、Python是如何进行类型转换的?
Python提供了将变量或值从一种类型转换为另一种类型的内置方法。
〔九〕、Python里面如何拷贝一个对象?
Python中对象之间的赋值是按引用传递的,如果要拷贝对象需要使用标准模板
中的copy
:浅拷贝,只拷贝父对象,不拷贝父对象的子对象。
py:深拷贝,拷贝父对象和子对象。
实用文档
.
〔十〕、__new__和__init__的区别。
__init__为初始化方法,__new__方法是真正的构造函数。
__new__是实例创立之前被调用,它的任务是创立并返回该实例,是静态方法
__init__是实例创立之后被调用的,然后设置对象属性的一些初始值。
总结:__new__方法在__init__方法之前被调用,并且__new__方法的返回值将传
递给__init__方法作为第一个参数,最后__init__给这个实例设置一些参数。
实用文档
.
想要更加详细的了解这两个方法,请点击:Python中的__new__及其用法
〔十一〕、Python中单下划线和双下划线分别是什么?
__name__:一种约定,Python内部的名字,用来与用户自定义的名字区分开,
防止冲突
_name:一种约定,用来指定变量私有
__name:解释器用_classname__name来代替这个名字用以区别和其他类相同
的命名
想要更加详细的了解这两者的区别,请点击:Python中的下划线〔译文〕
〔十二〕、说一说Python自省。
自省就是面向对象的语言所写的程序在运行时,所能知道对象的类型。简单一句
话就是运行时能够获得对象的类型。比方:type()、dir()、getattr()、hasattr()、
isinstance()
想要完整的理解Python自省,请点击:Python自省〔反射〕指南
有关于元类以及单例模式会在后面文章中做详细的解释说明。
本文参考文献资料:
实用文档
.
➢七、PYTHON一些根底面试题目总结
➢很全的Python面试题
➢Python自省〔反射〕指南
➢Python学习笔记〔十二〕:lambda表达式与函数式编程
➢Python面试必须要看的15个问题
〔十一〕Python书籍
入门书籍
➢【Python学习手册】
➢【HeadFirstPython】
➢【LearnPythonTheHardWay】
➢【Python编程:入门到实践】
➢【笨方法学Python】
➢【简明Python教程】
进阶书籍
➢【PythonCookbook〔第三版〕】
➢【流畅的Python】
➢【Python源码剖析】
➢【Python进阶】
➢【FlaskWeb开发:基于Python的Web应用开发实战】
本文发布于:2022-12-28 07:41:02,感谢您对本站的认可!
本文链接:http://www.wtabcd.cn/fanwen/fan/90/45468.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |