Python 爬虫面试题 170 道:2019 版
引言
最近在刷面试题,所以需要看大量的 python 相关的面试题,从大量的题目中总结了很多的知识,同时也对一些题目进行拓展了,但是在看了网上的大部分面试题不是很满意,一个是有些部分还是 python2 的代码,另一个就是回答的很简单,有些关键的题目,也没有点出为什么,最重要的是还有一些复制粘贴根本就跑不通,这种相信大家深有体会吧,这样就导致我们可能需要去找其他人发的类似的教程。难受啊,所以我决定针对市面上大多的 python 题目做一个分析,同时也希望大家尽可能的做到举一反三,而不是局限于题目本身。大概就这样吧,有你看过的题目也有你没看到过的。
通过本场 chat,你将获得如下知识点:
- 掌握 python 的基础语法
- 语法常见的 python 应用场景
- 掌握 python 闭包的使用以及装饰器的使用
- 生成器和迭代器的使用
- 常见的设计模式的使用
- 深浅拷贝的区别
- 线程、进程、协程的使用
- 了解 python 中的元编程和反射
- 常考的数据结构和算法
- 爬虫相关知识,网络编程基本知识等
所有题目
语言特性
1.谈谈对 python 和其他语言的区别
2.简述解释型和编译型编程语言
3.python 的解释器种类以及相关特点?
4.说说你知道的python3 和 python2 之间的区别?
5.python3 和 python2 中 int 和 long 区别?
6.xrange 和 range 的区别?
编码规范
7.什么是 pep8?
8.了解 python 之禅么?
9.了解 dosctring 么?
10.了解类型注解么?
11.例举你知道 python 对象的命名规范,例如方法或者类等
12.python 中的注释有几种?
13.如何优雅的给一个函数加注释?
14.如何给变量加注释?
15.python 代码缩进中是否支持 tab 键和空格混用。
16.是否可以在一句 import 中导入多个库?
17.在给 py 文件命名的时候需要注意什么?
18.例举几个规范 python 代码风格的工具
数据类型
字符串
19.列举 python 中的基本数据类型?
20.如何区别可变数据类型和不可变数据类型
21.将"hello world"转换为首字母大写"hello world"
22.如何检测字符串中只含有数字?
23.将字符串"ilovechina"进行反转
24.python 中的字符串格式化方式你知道哪些?
25.有一个字符串开头和末尾都有空格,比如“ adabdw ”,要求写一个函数把这个字符串的前后空格都去掉。
26.获取字符串”123456“最后的两个字符。
27.一个编码为 gbk 的字符串 s,要将其转成 utf-8 编码的字符串,应如何操作?
- (1)s="info:xiaozhang 33 shandong",用正则切分字符串输出'info', 'xiaozhang', '33', 'shandong' a = "你好 中国 ",去除多余空格只留一个空格。
- (1)怎样将字符串转换为小写 (2)单引号、双引号、三引号的区别?
列表
30.已知 alist = [1,2,3,1,2],对 alist 列表元素去重,写出具体过程。
31.如何实现 "1,2,3" 变成 ["1","2","3"]
32.给定两个 list,a 和 b,找出相同元素和不同元素
33.[[1,2],[3,4],[5,6]]一行代码展开该列表,得出[1,2,3,4,5,6]
34.合并列表[1,5,7,9]和[2,2,6,8]
35.如何打乱一个列表的元素?
字典
36.字典操作中 del 和 pop 有什么区别
37.按照字典的内的年龄排序
d1 = [ {'name':'alice', 'age':38}, {'name':'bob', 'age':18}, {'name':'carl', 'age':28}, ]
38.请合并下面两个字典 a = {"a":1,"b":2},b = {"c":3,"d":4}
39.如何使用生成式的方式生成一个字典,写一段功能代码。
40.如何把元组("a","b")和元组(1,2),变为字典{"a":1,"b":2}
综合
41.python 常用的数据结构的类型及其特性?
a:{1:0,2:0,3:0} b:{"a":0, "b":0, "c":0} c: {(1,2):0, (2,3):0} d: {[1,2]:0, [2,3]:0}
42.如何将元组("a","b")和元组(1,2),合并成字典{"a":1,"b":2}
43.python 里面如何实现 tuple 和 list 的转换?
44.我们知道对于列表可以使用切片操作进行部分元素的选择,那么如何对生成器类型的对象实现相同的功能呢?
45.请将[i for i in range(3)]改成生成器
46.a="hello"和 b="你好"编码成 bytes 类型
47.下面的代码输出结果是什么?
a = (1,2,3,[4,5,6,7],8) a[2] = 2
48.下面的代码输出的结果是什么?
a = (1,2,3,[4,5,6,7],8) a[3][0] = 2
操作类题目
49.python 交换两个变量的值
50.在读文件操作的时候会使用 read、readline 或者 readlines,简述它们各自的左右
51.json 序列化时,可以处理的数据类型有哪些?如何定制支持 datetime 类型?
52.json 序列化时,默认遇到中文会转换成 unicode,如果想要保留中文怎么办?
53.有两个磁盘文件 a 和 b,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列),输出到一个新文件 c 中。
54.如果当前的日期为 20190530,要求写一个函数输出 n 天后的日期,(比如 n 为 2,则输出 20190601)。
55.写一个函数,接收整数参数 n,返回一个函数,函数的功能是把函数的参数和 n 相乘并把结果返回。
56.下面代码会存在什么问题,如何改进?
def strappend(num): str='first' for i in range(num): str+=str(i) return str
57.一行代码输出 1-100 之间的所有偶数。
58.with 语句的作用,写一段代码?
59.python 字典和 json 字符串相互转化方法
60.请写一个 python 逻辑,计算一个文件中的大写字母数量
- 请写一段 python连接mongo数据库,然后的查询代码。
62.说一说redis的基本类型 - 请写一段 python连接redis数据库的代码。
- 请写一段 python连接mysql数据库的代码。
65.了解redis的事务么
66.了解数据库的三范式么?
67.了解分布式锁么
68.用 python 实现一个 reids 的分布式锁的功能
69.写一段 python 使用 mongo 数据库创建索引的代码
高级特效
70.函数装饰器有什么作用?请列举说明?
71.python 垃圾回收机制?
72.魔法函数 __call__怎么使用?
73.如何判断一个对象是函数还是方法?
74.@classmethod 和@staticmethod 用法和区别
75.python 中的接口如何实现?
76.python 中的反射了解么?
77.metaclass 作用?以及应用场景?
78.hasattr() getattr() setattr()的用法
79.请列举你知道的 python 的魔法方法及用途。
80.如何知道一个 python 对象的类型?
81.python 的传参是传值还是传址?
82.python 中的元类(metaclass)使用举例
83.简述 any()和 all()方法
84.filter 方法求出列表所有奇数并构造新列表,a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
85.什么是猴子补丁?
86.在 python 中是如何管理内存的?
87.当退出 python 时是否释放所有内存分配?
正则表达式
88.使用正则表达式匹配出<html><h1>www.baidu.com</html>中的地址
a="张明 98 分",用 re.sub,将 98 替换为 100
89.正则表达式匹配中(.*)和(.*?)匹配区别?
90.写一段匹配邮箱的正则表达式
其他内容
91.解释一下 python 中 pass 语句的作用?
92.简述你对 input()函数的理解
93.python 中的 is 和==
94.python 中的作用域
95.三元运算写法和应用场景?
96.了解 enumerate 么?
97.列举 5 个 python 中的标准模块
98.如何在函数中设置一个全局变量
99.pathlib 的用法举例
100.python 中的异常处理,写一个简单的应用场景
101.python 中递归的最大次数,那如何突破呢?
102.什么是面向对象的 mro
103.isinstance 作用以及应用场景?
104.什么是断言?应用场景?
105.lambda 表达式格式以及应用场景?
106.新式类和旧式类的区别
107.dir()是干什么用的?
108.一个包里有三个模块,demo1.py, demo2.py, demo3.py,但使用 from tools import *导入模块时,如何保证只有 demo1、demo3 被导入了。
109.列举 5 个 python 中的异常类型以及其含义
110.copy 和 deepcopy 的区别是什么?
111.代码中经常遇到的*args, **kwargs 含义及用法。
112.python 中会有函数或成员变量包含单下划线前缀和结尾,和双下划线前缀结尾,区别是什么?
113.w、a+、wb 文件写入模式的区别
114.举例 sort 和 sorted 的区别
115.什么是负索引?
116.pprint 模块是干什么的?
117.解释一下 python 中的赋值运算符
118.解释一下 python 中的逻辑运算符
119.讲讲 python 中的位运算符
120.在 python 中如何使用多进制数字?
121.怎样声明多个变量并赋值?
算法和数据结构
122.已知:
alist = [1,2,3] bset = {1,2,3}
(1) 从 alist 和 bset 中 查找 4,最坏时间复杂度那个大?
(2) 从 alist 和 bset 中 插入 4,最坏时间复杂度那个大?
123.用 python 实现一个二分查找的函数
124.python 单例模式的实现方法
125.使用 python 实现一个斐波那契数列
126.找出列表中的重复数字
127.找出列表中的单个数字
128.写一个冒泡排序
129.写一个快速排序
130.写一个拓扑排序
131.python 实现一个二进制计算
132.有一组“+”和“-”符号,要求将“+”排到左边,“-”排到右边,写出具体的实现方法。
133.单链表反转
134.交叉链表求交点
135.用队列实现栈
136.找出数据流的中位数
137.二叉搜索树中第 k 小的元素
爬虫相关
138.在 requests 模块中,requests.content 和 requests.text 什么区别
139.简要写一下 lxml 模块的使用方法框架
140.说一说 scrapy 的工作流程
141.scrapy 的去重原理
142.scrapy 中间件有几种类,你用过哪些中间件
143.你写爬虫的时候都遇到过什么?反爬虫措施,你是怎么解决的?
144.为什么会用到代理?
145.代理失效了怎么处理?
146.列出你知道 header 的内容以及信息
147.说一说打开浏览器访问 www.baidu.com 获取到结果,整个流程。
148.爬取速度过快出现了验证码怎么处理
149.scrapy 和 scrapy-redis 有什么区别?为什么选择 redis 数据库?
150.分布式爬虫主要解决什么问题
151.写爬虫是用多进程好?还是多线程好? 为什么?
152.解析网页的解析器使用最多的是哪几个
153.需要登录的网页,如何解决同时限制 ip,cookie,session(其中有一些是动态生成的)在不使用动态爬取的情况下?
154.验证码的解决(简单的:对图像做处理后可以得到的,困难的:验证码是点击,拖动等动态进行的?)
155.使用最多的数据库(mysql,mongodb,redis 等),对他的理解?
网络编程
156.tcp 和 udp 的区别?
157.简要介绍三次握手和四次挥手
158.什么是粘包? socket 中造成粘包的原因是什么? 哪些情况会发生粘包现象?
并发
159.举例说明 conccurent.future 的中线程池的用法
160.说一说多线程,多进程和协程的区别。
161.简述 gil
162.进程之间如何通信
163.io 多路复用的作用?
164.select、poll、epoll 模型的区别?
165.什么是并发和并行?
167.解释什么是异步非阻塞?
168.threading.local 的作用?
git 面试题
169.说说你知道的 git 命令
170.git 如何查看某次提交修改的内容
python面试题大合集