注意:你问答案在哪里?答案在视频里了,就是不给你写。
第一部分 Python基础篇(80题)
-
为什么学习Python?
- 简单易学 有丰富的第三方库 生态圈庞大 web开发 爬虫 人工智能 运维开发
-
通过什么途径学习的Python?
- 网上买的视屏教程 看技术贴 github
-
Python和Java、PHP、C、C#、C++等其他语言的对比?
- python php是解释型语言,代码运行期间逐行翻译成目标机器码,下次执行逐行翻译
- c c#编译型 编译后在执行
-
简述解释型和编译型编程语言?
- 解释型:边解释边执行(python php)
- 编译型:编译后在执行(c java c#)
-
Python解释器种类以及特点?
- cpython:c语言开发,官方推荐,最常用
- Ipython:基于cpyhon交互式解释器,只是在交互上有增强
- jpyhon:java写的解释器
- pypy:执行最快的解释器 采用jit技术 python 动态编译
- IronPython:c#写的解释器
-
位和字节的关系?
- 1字节=8位
- 1byte=8bit
-
b、B、KB、MB、GB 的关系?
- 1b=8bit
- 1kb=1024b
- 1mb=1024kb
- 1g=1024mb
- 1t=1024g
-
请至少列举5个 PEP8 规范(越多越好)。
- 空格使用
- 各种右括号前 不要家空格
- 逗号 冒号 分号前面不要加空格
- 函数左括号不要加空格func(1)
- 序号左括号前不要加空格list[2]
- 操作符左右各加一个空割不要为了对齐增加空格
- 不要将多句写在同一行,尽管使用;允许
- if/for/while语句中,执行语句只有一句也要另起一行
- 代码排序
- 缩进 4个空格 而不是tab键
- 每行长度79,换号可使用反撇好
- 类和类之间空2行
- 方法和方法空一行
- 空格使用
-
通过代码实现如下转换:
二进制转换成十进制:v = “0b1111011” #123 这个0b 表示开头 print(int(v))
十进制转换成二进制:v = 18 #1 0 0 10
八进制转换成十进制:v = “011”
十进制转换成八进制:v = 30
十六进制转换成十进制:v = “0x12”
十进制转换成十六进制:v = 87 -
请编写一个函数实现将IP地址转换成一个整数。
如 10.3.9.12 转换规则为:
10 00001010
3 00000011
9 00001001
12 00001100
再将以上二进制拼接起来计算十进制结果:00001010 00000011 00001001 00001100 = ? -
python递归的最大层数? 998
-
求结果:
v1 = 1 or 3 1
v2 = 1 and 3 3
v3 = 0 and 2 and 1 0
v4 = 0 and 2 or 1 1
v5 = 0 and 2 or 1 or 4 1
v6 = 0 or Flase and 1 flase-
######################## and:前后为真才为真 or:有一为真就为真 优先级:()>not>and>or 同等优先级下,从左向右
-
-
ascii、unicode、utf-8、gbk 区别?
-
#Ascii: 1个字节 支持英文 #unicode :所有字符(无论中文、英文等)1个字符:4个字节 #gbk : 1个字符,英文1个字节,中文2个字节。 #utf-8 :英文1个字节,欧洲字符:2个字节, 亚洲: 3个字节。
-
-
字节码和机器码的区别?
-
- C代码被编译成机器码(二进制),在机器上直接执行。 - Cpython编译你的python源代码,生成字节码。 - 机器码快的多,字节码更易迁移,也安全。
-
-
三元运算规则以及应用场景?
-
# 三元运算符就是在赋值变量的时候,可以直接加判断,然后赋值 a = 1 b = 2 c = a if a > 1 else b # 如果a大于1的话,c=a,否则c=b
-
-
列举 Python2和Python3的区别?
-
'Print': py2--print; py3--print()函数 '编码': py2默认是ascii码; py3默认是utf-8 '字符串': py2中分ascii(8位)、unicode(16位); py3中所有字符串都是unicode字符串 'True和False': py2中是两个全局变量(1和0)可以重新赋值; py3中为两个关键字,不可重新赋值 '迭代': py2:xrange; py3:range 'Nonlocal': py3专有的(声明为非局部变量) '经典类&新式类': py2:经典类和新式类并存; py3:新式类都默认继承object 'yield': py2:yield py3:yield/yield from '文件操作': py2:readliens()读取文件的所有行,返回一个列表,包含所有行的结束符 xreadliens()返回一个生成器,循环取值 py3: 只有readlines()
-
-
用一行代码实现数值交换: a = 1 b = 2
-
a, b = b, a print(a, b)
-
-
Python3和Python2中 int 和 long的区别?
- 在python3里,只有一种整数类型int,大多数情况下,和python2中的长整型类似。
-
xrange和range的区别?
-
#range产生的是一个列表,xrange产生的是生成器。 #数据较大时xrange比range好。 #Range一下把数据都返回,xrange通过yield每次返回一个。
-
-
文件操作时:xreadlines和readlines的区别?
-
# Readlines:读取文件的所有行,返回一个列表,包含所有行的结束符 # Xreadlines:返回一个生成器,循环使用和readlines基本一致 。(py2有,py3没有)
-
-
列举布尔值为False的常见值?
-
[]、{}、None、’’、()、0、False
-
-
字符串、列表、元组、字典每个常用的5个方法?
-
#Str: Split:分割 Strip:去掉两边的空格 Startwith:以什么开头 Endwith:以什么结尾 Lower:小写 Upper:大写 #List: Append:追加 Insert:插入 Reverse:反转 Index:索引 Copy:拷贝 Pop:删除指定索引处的值,不指定索引默认删除最后一个。 #Tuple: Count:查看某个元素出现的次数 Index:索引 #Dict: Get:根据key取value Items:用于循环,取出所有key和value Keys:取出所有key Values:取出所有的value Clear:清空字典 Pop:删除指定键对应的值,有返回值;
-
-
lambda表达式格式以及应用场景?
-
匿名函数:为了解决那些功能很简单的需求而设计的一句话函数
lambda 表达式 temp = lambda x,y:x+y print(temp(4,10)) # 14
-
-
pass的作用?
- pass是空语句,是为了保持程序结构的完整性。pass 不做任何事情,一般用做占位语句。
-
*arg和**kwarg作用
-
*args代表位置参数,它会接收任意多个参数并把这些参数作为元祖传递给函数。
**kwargs代表的关键字参数,返回的是字典,位置参数一定要放在关键字前面
-
-
is和==的区别
-
# a == str3 True == ---> 只需要内容相等 # a is str3 False is ---> 只需要内存地址相等
-
-
简述Python的深浅拷贝以及应用场景?
-
#浅拷贝: 不管多么复杂的数据结构,只copy对象最外层本身,该对象引用的其他对象不copy, 内存里两个变量的地址是一样的,一个改变另一个也改变。 #深拷贝: 完全复制原变量的所有数据,内存中生成一套完全一样的内容;只是值一样,内存地址不一样,一方修改另一方不受影响
-
-
Python垃圾回收机制?
-
Python垃圾回收机制,主要使用'引用计数'来跟踪和回收垃圾。 在'引用计数'的基础上,通过'标记-清除'(mark and sweep)解决容器对象可能产生的循环引用问题. 通过'分代回收'以空间换时间的方法提高垃圾回收效率。
-
-
Python的可变类型和不可变类型?
-
# 可变类型:列表、字典、集合 # 不可变类型:数字、字符串、元祖
-
-
求结果:
v = dict.fromkeys(['k1','k2'],[])
v[‘k1’].append(666)
print(v) #{'k1':[666],'k2':[666]}
v[‘k1’] = 777
print(v)#{'k1':777,'k2':[666]} -
求结果:
-
def multipliers(): return [lambda x:i*x for i in range(4)] print([m(2) for m in multipliers()]) #解释: 函数返回值为一个列表表达式,经过4次循环结果为包含四个lambda函数的列表, 由于函数未被调用,循环中的i值未被写入函数,经过多次替代,循环结束后i值为3, 故结果为:6,6,6,6
-
-
列举常见的内置函数?
- lambda
- fn =lambda a,b:a+b
- fn(3,5)
- abs
-
例子2:abs() 返回数字的绝对值
ret = map(abs,[-1,-5,6,-7])
print(list(ret))
# [1, 5, 6, 7] - filter
- print(sorted (lst, key=lambda s:len(s)))
- lst=[{"name":"alex","shengao":150,"tizhong":200}]
- print(sorted (lst, key=lambda dic:dic["tizhong"],reverse=True))
- print(sorted (lst, key=lambda s:len(s)))
- map
- lst=["篮球","台球","唱歌"]
- m=map(lambda s:"爱好"+s,lst)
- filter 过滤
- f=filter(lamdba d:d["tizhong"] <=180, lst)
- 过来体重小于等于180的
- lambda
-
filter、map、reduce的作用?
-
# map:遍历序列,为每一个序列进行操作,获取一个新的序列 # reduce:对于序列里面的所有内容进行累计操作
-
-
# filter:对序列里面的元素进行筛选,最终获取符合条件的序列。
-
-
一行代码实现9*9乘法表
-
print('\n'.join([' '.join(['%s*%s=%-2s' % (j, i, i * j) for j in range(1, i + 1)]) for i in range(1, 10)]))
-
-
如何安装第三方模块?以及用过哪些第三方模块?
-
1:pip包管理器 2:源码下载 -下载 -解压 -python setup.py build -python setup.py install
-
-
至少列举8个常用模块都有那些?
-
re:正则 os:提供了一种方便的使用操作系统函数的方法。 sys:可供访问由解释器使用或维护的变量和与解释器进行交互的函数。 random:随机数 json:序列化 time:时间
- 爬虫里面的bs4
-
-
re的match和search区别?
-
# match:从字符串起始位置开始匹配,如果没有就返回None # serch:从字符串的起始位置开始匹配,匹配到第一个符合的就不会再去匹配了
-
-
什么是正则的贪婪匹配?
-
# 匹配一个字符串没有节制,能匹配多少就匹配多少,直到匹配完为
-
-
求结果: a. [ i % 2 for i in range(10) ] b. ( i % 2 for i in range(10) )
-
# a结果是一个列表生成式,结果是一个列表(i % 2为生成的元素): [0, 1, 0, 1, 0, 1, 0, 1, 0, 1] # b结果是一个生成器
-
-
求结果: a. 1 or 2 b. 1 and 2 c. 1 < (2==2) d. 1 < 2 == 2
-
a=1 or 2 #1 b=1 and 2 #2 c=1 < (2==2) #False d=1 < 2 == 2 #True
-
-
def func(a,b=[]) 这种写法有什么坑?
-
def func(a,b = []): b.append(1) print(a,b) func(a=2) func(2) func(2) ''' 2 [1] 2 [1, 1] 2 [1, 1, 1] 函数的默认参数是一个list 当第一次执行的时候实例化了一个list 第二次执行还是用第一次执行的时候实例化的地址存储 所以三次执行的结果就是 [1, 1, 1] 想每次执行只输出[1] ,默认参数应该设置为None '''
-
-
如何实现 “1,2,3” 变成 [‘1’,’2’,’3’] ?
-
a = '1,2,3' a=a.replace(',','')
- a='123'
-
res = [i for i in a] print(res)
-
list("1,2,3".split(','))
-
-
如何实现[‘1’,’2’,’3’]变成[1,2,3] ?
-
l = ['1','2','3'] res = [int(i) for i in l] print(res)
-
-
比较: a = [1,2,3] 和 b = [(1),(2),(3) ] 以及 b = [(1,),(2,),(3,) ] 的区别?
-
前两个列表内是int 最后一个列表内是元组
-
-
如何用一行代码生成[1,4,9,16,25,36,49,64,81,100] ?
-
l = [i*i for i in range(1,11)] print(l)
-
-
一行代码实现删除列表中重复的值 ?
-
l = [1,1,1,2,2,3,3,3,4,4] print(list(set(l))) # [1, 2, 3, 4]
-
-
如何在函数中设置一个全局变量 ?
-
通过global指定变量,该变量会变成全局变量
-
-
logging模块的作用?以及应用场景?
-
# 作用: 管理我们程序的执行日志,省去用print记录操作日志的操作,并且可以将标准输入输出保存到日志文件 # 场景: 爬虫爬取数据时,对爬取进行日志记录,方便分析、排错。
-
-
请用代码简答实现stack 。
-
- Stack() 创建一个新的空栈
- push(item) 添加一个新的元素item到栈顶
- pop() 弹出栈顶元素
- peek() 返回栈顶元素
- is_empty() 判断栈是否为空
- size() 返回栈的元素个数
-
# 实现一个栈stack,后进先出 ''' class Stack: def __init__(self): self.items = [] def is_empty(self): # 判断是否为空 return self.items == [] def push(self,item): # 加入元素 self.items.append(item) def pop(self): # 弹出元素 return self.items.pop() def peek(self): # 返回栈顶元素 return self.items[len(self.items)-1] def size(self): # 返回栈的大小 return len(self.items) if __name__ == "__main__": stack = Stack() stack.push("H") stack.push("E") stack.push("L") print(stack.size()) # 3 print(stack.peek()) # L print(stack.pop()) # L print(stack.pop()) # E print(stack.pop()) # H '''
-
-
常用字符串格式化哪几种?
-
简述 生成器、迭代器、可迭代对象 以及应用场景?
-
用Python实现一个二分查找的函数。
-
谈谈你对闭包的理解?
-
os和sys模块的作用?
-
如何生成一个随机数?
-
如何使用python删除一个文件?
-
谈谈你对面向对象的理解?
-
Python面向对象中的继承有什么特点?
-
面向对象深度优先和广度优先是什么?
-
面向对象中super的作用?
-
是否使用过functools中的函数?其作用是什么?
-
列举面向对象中带爽下划线的特殊方法,如:__new__、__init__
-
如何判断是函数还是方法?
-
静态方法和类方法区别?
-
列举面向对象中的特殊成员以及应用场景
-
1、2、3、4、5 能组成多少个互不相同且无重复的三位数
-
什么是反射?以及应用场景?
-
metaclass作用?以及应用场景?
-
用尽量多的方法实现单例模式。
-
装饰器的写法以及应用场景。
-
异常处理写法以及如何主动跑出异常(应用场景)
-
什么是面向对象的mro
-
isinstance作用以及应用场景?
- 写代码并实现:
Given an array of integers, return indices of the two numbers such that they add up to a specific target.You may assume that each input would
have exactly one solution, and you may not use the same element twice.
Example:
Given nums = [2, 7, 11, 15], target = 9,
Because nums[0] + nums[1] = 2 + 7 = 9,
return [0, 1] -
json序列化时,可以处理的数据类型有哪些?如何定制支持datetime类型?
-
json序列化时,默认遇到中文会转换成unicode,如果想要保留中文怎么办?
-
什么是断言?应用场景?
-
有用过with statement吗?它的好处是什么?
-
使用代码实现查看列举目录下的所有文件。
-
简述 yield和yield from关键字。
第二部分 网络编程和并发(34题)
-
简述 OSI 七层协议。
-
什么是C/S和B/S架构?
-
简述 三次握手、四次挥手的流程。
-
什么是arp协议?
-
TCP和UDP的区别?
-
什么是局域网和广域网?
-
为何基于tcp协议的通信比基于udp协议的通信更可靠?
-
什么是socket?简述基于tcp协议的套接字通信流程。
-
什么是粘包? socket 中造成粘包的原因是什么? 哪些情况会发生粘包现象?
-
IO多路复用的作用?
-
什么是防火墙以及作用?
-
select、poll、epoll 模型的区别?
-
简述 进程、线程、协程的区别 以及应用场景?
-
GIL锁是什么鬼?
-
Python中如何使用线程池和进程池?
-
threading.local的作用?
-
进程之间如何进行通信?
-
什么是并发和并行?
-
进程锁和线程锁的作用?
-
解释什么是异步非阻塞?
-
路由器和交换机的区别?
-
什么是域名解析?
-
如何修改本地hosts文件?
-
生产者消费者模型应用场景及优势?
-
什么是cdn?
-
LVS是什么及作用?
-
Nginx是什么及作用?
-
keepalived是什么及作用?
-
haproxy是什么以及作用?
-
什么是负载均衡?
-
什么是rpc及应用场景?
-
简述 asynio模块的作用和应用场景。
-
简述 gevent模块的作用和应用场景。
-
twisted框架的使用和应用?
第三部分 数据库和缓存(46题)
-
列举常见的关系型数据库和非关系型都有那些?
-
MySQL常见数据库引擎及比较?
-
简述数据三大范式?
-
什么是事务?MySQL如何支持事务?
-
简述数据库设计中一对多和多对多的应用场景?
-
如何基于数据库实现商城商品计数器?
-
常见SQL(必备)
详见武沛齐博客:https://www.cnblogs.com/wupeiqi/articles/5729934.html -
简述触发器、函数、视图、存储过程?
-
MySQL索引种类
-
索引在什么情况下遵循最左前缀的规则?
-
主键和外键的区别?
-
MySQL常见的函数?
-
列举 创建索引但是无法命中索引的8种情况。
-
如何开启慢日志查询?
-
数据库导入导出命令(结构+数据)?
-
数据库优化方案?
-
char和varchar的区别?
-
简述MySQL的执行计划?
-
在对name做了唯一索引前提下,简述以下区别:
select * from tb where name = ‘Oldboy-Wupeiqi’
select * from tb where name = ‘Oldboy-Wupeiqi’ limit 1 -
1000w条数据,使用limit offset 分页时,为什么越往后翻越慢?如何解决?
-
什么是索引合并?
-
什么是覆盖索引?
-
简述数据库读写分离?
-
简述数据库分库分表?(水平、垂直)
-
redis和memcached比较?
-
redis中数据库默认是多少个db 及作用?
-
python操作redis的模块?
-
如果redis中的某个列表中的数据量非常大,如果实现循环显示每一个值?
-
redis如何实现主从复制?以及数据同步机制?
-
redis中的sentinel的作用?
-
如何实现redis集群?
-
redis中默认有多少个哈希槽?
-
简述redis的有哪几种持久化策略及比较?
-
列举redis支持的过期策略。
-
MySQL 里有 2000w 数据,redis 中只存 20w 的数据,如何保证 redis 中都是热点数据?
-
写代码,基于redis的列表实现 先进先出、后进先出队列、优先级队列。
-
如何基于redis实现消息队列?
-
如何基于redis实现发布和订阅?以及发布订阅和消息队列的区别?
-
什么是codis及作用?
-
什么是twemproxy及作用?
-
写代码实现redis事务操作。
-
redis中的watch的命令的作用?
-
基于redis如何实现商城商品数量计数器?
-
简述redis分布式锁和redlock的实现机制。
-
什么是一致性哈希?Python中是否有相应模块?
-
如何高效的找到redis中所有以oldboy开头的key?
第四部分 前端、框架和其他(155题)
-
谈谈你对http协议的认识。
-
谈谈你对websocket协议的认识。
-
什么是magic string ?
-
如何创建响应式布局?
-
你曾经使用过哪些前端框架?
-
什么是ajax请求?并使用jQuery和XMLHttpRequest对象实现一个ajax请求。
-
如何在前端实现轮训?
-
如何在前端实现长轮训?
-
vuex的作用?
-
vue中的路由的拦截器的作用?
-
axios的作用?
-
列举vue的常见指令。
-
简述jsonp及实现原理?
-
是什么cors ?
-
列举Http请求中常见的请求方式?
-
列举Http请求中的状态码?
-
列举Http请求中常见的请求头?
-
看图写结果:
-
看图写结果:
-
看图写结果:
-
看图写结果:
-
看图写结果:
-
看图写结果:
-
django、flask、tornado框架的比较?
-
什么是wsgi?
-
django请求的生命周期?
-
列举django的内置组件?
-
列举django中间件的5个方法?以及django中间件的应用场景?
-
简述什么是FBV和CBV?
-
django的request对象是在什么时候创建的?
-
如何给CBV的程序添加装饰器?
-
列举django orm 中所有的方法(QuerySet对象的所有方法)
-
only和defer的区别?
-
select_related和prefetch_related的区别?
-
filter和exclude的区别?
-
列举django orm中三种能写sql语句的方法。
-
django orm 中如何设置读写分离?
-
F和Q的作用?
-
values和values_list的区别?
-
如何使用django orm批量创建数据?
-
django的Form和ModeForm的作用?
-
django的Form组件中,如果字段中包含choices参数,请使用两种方式实现数据源实时更新。
-
django的Model中的ForeignKey字段中的on_delete参数有什么作用?
-
django中csrf的实现机制?
-
django如何实现websocket?
-
基于django使用ajax发送post请求时,都可以使用哪种方法携带csrf token?
-
django中如何实现orm表中添加数据时创建一条日志记录。
-
django缓存如何设置?
-
django的缓存能使用redis吗?如果可以的话,如何配置?
-
django路由系统中name的作用?
-
django的模板中filter和simple_tag的区别?
-
django-debug-toolbar的作用?
-
django中如何实现单元测试?
-
解释orm中 db first 和 code first的含义?
-
django中如何根据数据库表生成model中的类?
-
使用orm和原生sql的优缺点?
-
简述MVC和MTV
-
django的contenttype组件的作用?
-
谈谈你对restfull 规范的认识?
-
接口的幂等性是什么意思?
-
什么是RPC?
-
Http和Https的区别?
-
为什么要使用django rest framework框架?
-
django rest framework框架中都有那些组件?
-
django rest framework框架中的视图都可以继承哪些类?
-
简述 django rest framework框架的认证流程。
-
django rest framework如何实现的用户访问频率控制?
-
Flask框架的优势?
-
Flask框架依赖组件?
-
Flask蓝图的作用?
-
列举使用过的Flask第三方组件?
-
简述Flask上下文管理流程?
-
Flask中的g的作用?
-
Flask中上下文管理主要涉及到了那些相关的类?并描述类主要作用?
-
为什么要Flask把Local对象中的的值stack 维护成一个列表?
-
Flask中多app应用是怎么完成?
-
在Flask中实现WebSocket需要什么组件?
-
wtforms组件的作用?
-
Flask框架默认session处理机制?
-
解释Flask框架中的Local对象和threading.local对象的区别?
-
Flask中 blinker 是什么?
-
SQLAlchemy中的 session和scoped_session 的区别?
-
SQLAlchemy如何执行原生SQL?
-
ORM的实现原理?
-
DBUtils模块的作用?
- 以下SQLAlchemy的字段是否正确?如果不正确请更正:
1234567891011
from
datetime
import
datetime
from
sqlalchemy.ext.declarative
import
declarative_base
from
sqlalchemy
import
Column, Integer, String, DateTime
Base
=
declarative_base()
class
UserInfo(Base):
__tablename__
=
'userinfo'
id
=
Column(Integer, primary_key
=
True
, autoincrement
=
True
)
name
=
Column(String(
64
), unique
=
True
)
ctime
=
Column(DateTime, default
=
datetime.now())
-
SQLAchemy中如何为表设置引擎和字符编码?
-
SQLAchemy中如何设置联合唯一索引?
-
简述Tornado框架的特点。
-
简述Tornado框架中Future对象的作用?
-
Tornado框架中如何编写WebSocket程序?
-
Tornado中静态文件是如何处理的? 如: <link href="{{static_url("commons.css")}}" rel="stylesheet" />
-
Tornado操作MySQL使用的模块?
-
Tornado操作redis使用的模块?
-
简述Tornado框架的适用场景?
-
git常见命令作用:
-
简述以下git中stash命令作用以及相关其他命令。
-
git 中 merge 和 rebase命令 的区别。
-
公司如何基于git做的协同开发?
-
如何基于git实现代码review?
-
git如何实现v1.0 、v2.0 等版本的管理?
-
什么是gitlab?
-
github和gitlab的区别?
-
如何为github上牛逼的开源项目贡献代码?
-
git中 .gitignore文件的作用?
-
什么是敏捷开发?
-
简述 jenkins 工具的作用?
-
公司如何实现代码发布?
-
简述 RabbitMQ、Kafka、ZeroMQ的区别?
-
RabbitMQ如何在消费者获取任务后未处理完前就挂掉时,保证数据不丢失?
-
RabbitMQ如何对消息做持久化?
-
RabbitMQ如何控制消息被消费的顺序?
-
以下RabbitMQ的exchange type分别代表什么意思?如:fanout、direct、topic。
-
简述 celery 是什么以及应用场景?
-
简述celery运行机制。
-
celery如何实现定时任务?
-
简述 celery多任务结构目录?
-
celery中装饰器 @app.task 和 @shared_task的区别?
-
简述 requests模块的作用及基本使用?
-
简述 beautifulsoup模块的作用及基本使用?
-
简述 seleninu模块的作用及基本使用?
-
scrapy框架中各组件的工作流程?
-
在scrapy框架中如何设置代理(两种方法)?
-
scrapy框架中如何实现大文件的下载?
-
scrapy中如何实现限速?
-
scrapy中如何实现暂定爬虫?
-
scrapy中如何进行自定制命令?
-
scrapy中如何实现的记录爬虫的深度?
-
scrapy中的pipelines工作原理?
-
scrapy的pipelines如何丢弃一个item对象?
-
简述scrapy中爬虫中间件和下载中间件的作用?
-
scrapy-redis组件的作用?
-
scrapy-redis组件中如何实现的任务的去重?
-
scrapy-redis的调度器如何实现任务的深度优先和广度优先?
-
简述 vitualenv 及应用场景?
-
简述 pipreqs 及应用场景?
-
在Python中使用过什么代码检查工具?
-
简述 saltstack、ansible、fabric、puppet工具的作用?
-
B Tree和B+ Tree的区别?
-
请列举常见排序并通过代码实现任意三种。
-
请列举常见查找并通过代码实现任意三种。
-
请列举你熟悉的设计模式?
-
有没有刷过leetcode?
-
列举熟悉的的Linux命令。
-
公司线上服务器是什么系统?
-
解释 PV、UV 的含义?
-
解释 QPS的含义?
-
uwsgi和wsgi的区别?
-
supervisor的作用?
-
什么是反向代理?
-
简述SSH的整个过程。
-
有问题都去那些找解决方案?
-
是否有关注什么技术类的公众号?
-
最近在研究什么新技术?
-
是否了解过领域驱动模型?
统计:80 + 34 + 46 + 155 = 315题