第一部分 Python基础篇(80题)
-
为什么学习Python?
-
通过什么途径学习的Python?
-
Python和Java、PHP、C、C#、C++等其他语言的对比?
-
简述解释型和编译型编程语言?
-
Python解释器种类以及特点?
-
位和字节的关系?
-
b、B、KB、MB、GB 的关系?
-
请至少列举5个 PEP8 规范(越多越好)。
- 通过代码实现如下转换:
二进制转换成十进制:v = “0b1111011”
十进制转换成二进制:v = 18
八进制转换成十进制: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递归的最大层数?
- 求结果:
v1 = 1 or 3
v2 = 1 and 3
v3 = 0 and 2 and 1
v4 = 0 and 2 or 1
v5 = 0 and 2 or 1 or 4
v6 = 0 or Flase and 1 -
ascii、unicode、utf-8、gbk 区别?
-
字节码和机器码的区别?
-
三元运算规则以及应用场景?
-
列举 Python2和Python3的区别?
-
用一行代码实现数值交换:
a = 1
b = 2 -
Python3和Python2中 int 和 long的区别?
-
xrange和range的区别?
-
文件操作时:xreadlines和readlines的区别?
-
列举布尔值为False的常见值?
-
字符串、列表、元组、字典每个常用的5个方法?
-
lambda表达式格式以及应用场景?
-
pass的作用?
-
*arg和**kwarg作用
-
is和==的区别
-
简述Python的深浅拷贝以及应用场景?
-
Python垃圾回收机制?
-
Python的可变类型和不可变类型?
- 求结果:
v = dict.fromkeys(['k1','k2'],[])
v[‘k1’].append(666)
print(v)
v[‘k1’] = 777
print(v) - 求结果:
-
列举常见的内置函数?
-
filter、map、reduce的作用?
-
一行代码实现9*9乘法表
-
如何安装第三方模块?以及用过哪些第三方模块?
-
至少列举8个常用模块都有那些?
-
re的match和search区别?
-
什么是正则的贪婪匹配?
-
求结果: a. [ i % 2 for i in range(10) ] b. ( i % 2 for i in range(10) )
-
求结果&#xff1a; a. 1 or 2 b. 1 and 2 c. 1 <(2&#61;&#61;2) d. 1 <2 &#61;&#61; 2
-
def func(a,b&#61;[]) 这种写法有什么坑&#xff1f;
-
如何实现 “1,2,3” 变成 [‘1’,’2’,’3’] ?
-
如何实现[‘1’,’2’,’3’]变成[1,2,3] ?
-
比较&#xff1a; a &#61; [1,2,3] 和 b &#61; [(1),(2),(3) ] 以及 b &#61; [(1,),(2,),(3,) ] 的区别&#xff1f;
-
如何用一行代码生成[1,4,9,16,25,36,49,64,81,100] ?
-
一行代码实现删除列表中重复的值 ?
-
如何在函数中设置一个全局变量 ?
-
logging模块的作用&#xff1f;以及应用场景&#xff1f;
-
请用代码简答实现stack 。
-
常用字符串格式化哪几种&#xff1f;
-
简述 生成器、迭代器、可迭代对象 以及应用场景&#xff1f;
-
用Python实现一个二分查找的函数。
-
谈谈你对闭包的理解&#xff1f;
-
os和sys模块的作用&#xff1f;
-
如何生成一个随机数&#xff1f;
-
如何使用python删除一个文件&#xff1f;
-
谈谈你对面向对象的理解&#xff1f;
-
Python面向对象中的继承有什么特点&#xff1f;
-
面向对象深度优先和广度优先是什么&#xff1f;
-
面向对象中super的作用&#xff1f;
-
是否使用过functools中的函数&#xff1f;其作用是什么&#xff1f;
-
列举面向对象中带爽下划线的特殊方法&#xff0c;如&#xff1a;__new__、__init__
-
如何判断是函数还是方法&#xff1f;
-
静态方法和类方法区别&#xff1f;
-
列举面向对象中的特殊成员以及应用场景
-
1、2、3、4、5 能组成多少个互不相同且无重复的三位数
-
什么是反射&#xff1f;以及应用场景&#xff1f;
-
metaclass作用&#xff1f;以及应用场景&#xff1f;
-
用尽量多的方法实现单例模式。
-
装饰器的写法以及应用场景。
-
异常处理写法以及如何主动跑出异常&#xff08;应用场景&#xff09;
-
什么是面向对象的mro
-
isinstance作用以及应用场景&#xff1f;
- 写代码并实现&#xff1a;
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 &#61; [2, 7, 11, 15], target &#61; 9,
Because nums[0] &#43; nums[1] &#61; 2 &#43; 7 &#61; 9,
return [0, 1] -
json序列化时&#xff0c;可以处理的数据类型有哪些&#xff1f;如何定制支持datetime类型&#xff1f;
-
json序列化时&#xff0c;默认遇到中文会转换成unicode&#xff0c;如果想要保留中文怎么办&#xff1f;
-
什么是断言&#xff1f;应用场景&#xff1f;
-
有用过with statement吗&#xff1f;它的好处是什么&#xff1f;
-
使用代码实现查看列举目录下的所有文件。
-
简述 yield和yield from关键字。
第二部分 网络编程和并发&#xff08;34题&#xff09;
-
简述 OSI 七层协议。
-
什么是C/S和B/S架构&#xff1f;
-
简述 三次握手、四次挥手的流程。
-
什么是arp协议&#xff1f;
-
TCP和UDP的区别&#xff1f;
-
什么是局域网和广域网&#xff1f;
-
为何基于tcp协议的通信比基于udp协议的通信更可靠&#xff1f;
-
什么是socket&#xff1f;简述基于tcp协议的套接字通信流程。
-
什么是粘包&#xff1f; socket 中造成粘包的原因是什么&#xff1f; 哪些情况会发生粘包现象&#xff1f;
-
IO多路复用的作用&#xff1f;
-
什么是防火墙以及作用&#xff1f;
-
select、poll、epoll 模型的区别&#xff1f;
-
简述 进程、线程、协程的区别 以及应用场景&#xff1f;
-
GIL锁是什么鬼&#xff1f;
-
Python中如何使用线程池和进程池&#xff1f;
-
threading.local的作用&#xff1f;
-
进程之间如何进行通信&#xff1f;
-
什么是并发和并行&#xff1f;
-
进程锁和线程锁的作用&#xff1f;
-
解释什么是异步非阻塞&#xff1f;
-
路由器和交换机的区别&#xff1f;
-
什么是域名解析&#xff1f;
-
如何修改本地hosts文件&#xff1f;
-
生产者消费者模型应用场景及优势&#xff1f;
-
什么是cdn&#xff1f;
-
LVS是什么及作用&#xff1f;
-
Nginx是什么及作用&#xff1f;
-
keepalived是什么及作用?
-
haproxy是什么以及作用&#xff1f;
-
什么是负载均衡&#xff1f;
-
什么是rpc及应用场景&#xff1f;
-
简述 asynio模块的作用和应用场景。
-
简述 gevent模块的作用和应用场景。
-
twisted框架的使用和应用&#xff1f;
第三部分 数据库和缓存&#xff08;46题&#xff09;
-
列举常见的关系型数据库和非关系型都有那些&#xff1f;
-
MySQL常见数据库引擎及比较&#xff1f;
-
简述数据三大范式&#xff1f;
-
什么是事务&#xff1f;MySQL如何支持事务&#xff1f;
-
简述数据库设计中一对多和多对多的应用场景&#xff1f;
-
如何基于数据库实现商城商品计数器&#xff1f;
-
常见SQL&#xff08;必备&#xff09;
详见武沛齐博客&#xff1a;https://www.cnblogs.com/wupeiqi/articles/5729934.html -
简述触发器、函数、视图、存储过程&#xff1f;
-
MySQL索引种类
-
索引在什么情况下遵循最左前缀的规则&#xff1f;
-
主键和外键的区别&#xff1f;
-
MySQL常见的函数&#xff1f;
-
列举 创建索引但是无法命中索引的8种情况。
-
如何开启慢日志查询&#xff1f;
-
数据库导入导出命令&#xff08;结构&#43;数据&#xff09;&#xff1f;
-
数据库优化方案&#xff1f;
-
char和varchar的区别&#xff1f;
-
简述MySQL的执行计划&#xff1f;
-
在对name做了唯一索引前提下&#xff0c;简述以下区别&#xff1a;
select * from tb where name &#61; ‘Oldboy-Wupeiqi’
select * from tb where name &#61; ‘Oldboy-Wupeiqi’ limit 1 -
1000w条数据&#xff0c;使用limit offset 分页时&#xff0c;为什么越往后翻越慢&#xff1f;如何解决&#xff1f;
-
什么是索引合并&#xff1f;
-
什么是覆盖索引&#xff1f;
-
简述数据库读写分离&#xff1f;
-
简述数据库分库分表&#xff1f;&#xff08;水平、垂直&#xff09;
-
redis和memcached比较&#xff1f;
-
redis中数据库默认是多少个db 及作用&#xff1f;
-
python操作redis的模块&#xff1f;
-
如果redis中的某个列表中的数据量非常大&#xff0c;如果实现循环显示每一个值&#xff1f;
-
redis如何实现主从复制&#xff1f;以及数据同步机制&#xff1f;
-
redis中的sentinel的作用&#xff1f;
-
如何实现redis集群&#xff1f;
-
redis中默认有多少个哈希槽&#xff1f;
-
简述redis的有哪几种持久化策略及比较&#xff1f;
-
列举redis支持的过期策略。
-
MySQL 里有 2000w 数据&#xff0c;redis 中只存 20w 的数据&#xff0c;如何保证 redis 中都是热点数据&#xff1f;
-
写代码&#xff0c;基于redis的列表实现 先进先出、后进先出队列、优先级队列。
-
如何基于redis实现消息队列&#xff1f;
-
如何基于redis实现发布和订阅&#xff1f;以及发布订阅和消息队列的区别&#xff1f;
-
什么是codis及作用&#xff1f;
-
什么是twemproxy及作用&#xff1f;
-
写代码实现redis事务操作。
-
redis中的watch的命令的作用&#xff1f;
-
基于redis如何实现商城商品数量计数器&#xff1f;
-
简述redis分布式锁和redlock的实现机制。
-
什么是一致性哈希&#xff1f;Python中是否有相应模块&#xff1f;
-
如何高效的找到redis中所有以oldboy开头的key&#xff1f;
第四部分 前端、框架和其他&#xff08;155题&#xff09;
-
谈谈你对http协议的认识。
-
谈谈你对websocket协议的认识。
-
什么是magic string &#xff1f;
-
如何创建响应式布局&#xff1f;
-
你曾经使用过哪些前端框架&#xff1f;
-
什么是ajax请求&#xff1f;并使用jQuery和XMLHttpRequest对象实现一个ajax请求。
-
如何在前端实现轮训&#xff1f;
-
如何在前端实现长轮训&#xff1f;
-
vuex的作用&#xff1f;
-
vue中的路由的拦截器的作用&#xff1f;
-
axios的作用&#xff1f;
-
列举vue的常见指令。
-
简述jsonp及实现原理&#xff1f;
-
是什么cors &#xff1f;
-
列举Http请求中常见的请求方式&#xff1f;
-
列举Http请求中的状态码&#xff1f;
-
列举Http请求中常见的请求头&#xff1f;
-
看图写结果&#xff1a;
-
看图写结果&#xff1a;
-
看图写结果&#xff1a;
-
看图写结果&#xff1a;
-
看图写结果&#xff1a;
-
看图写结果&#xff1a;
-
django、flask、tornado框架的比较&#xff1f;
-
什么是wsgi&#xff1f;
-
django请求的生命周期&#xff1f;
-
列举django的内置组件&#xff1f;
-
列举django中间件的5个方法&#xff1f;以及django中间件的应用场景&#xff1f;
-
简述什么是FBV和CBV&#xff1f;
-
django的request对象是在什么时候创建的&#xff1f;
-
如何给CBV的程序添加装饰器&#xff1f;
-
列举django orm 中所有的方法&#xff08;QuerySet对象的所有方法&#xff09;
-
only和defer的区别&#xff1f;
-
select_related和prefetch_related的区别&#xff1f;
-
filter和exclude的区别&#xff1f;
-
列举django orm中三种能写sql语句的方法。
-
django orm 中如何设置读写分离&#xff1f;
-
F和Q的作用?
-
values和values_list的区别&#xff1f;
-
如何使用django orm批量创建数据&#xff1f;
-
django的Form和ModeForm的作用&#xff1f;
-
django的Form组件中&#xff0c;如果字段中包含choices参数&#xff0c;请使用两种方式实现数据源实时更新。
-
django的Model中的ForeignKey字段中的on_delete参数有什么作用&#xff1f;
-
django中csrf的实现机制&#xff1f;
-
django如何实现websocket&#xff1f;
-
基于django使用ajax发送post请求时&#xff0c;都可以使用哪种方法携带csrf token&#xff1f;
-
django中如何实现orm表中添加数据时创建一条日志记录。
-
django缓存如何设置&#xff1f;
-
django的缓存能使用redis吗&#xff1f;如果可以的话&#xff0c;如何配置&#xff1f;
-
django路由系统中name的作用&#xff1f;
-
django的模板中filter和simple_tag的区别&#xff1f;
-
django-debug-toolbar的作用&#xff1f;
-
django中如何实现单元测试&#xff1f;
-
解释orm中 db first 和 code first的含义&#xff1f;
-
django中如何根据数据库表生成model中的类&#xff1f;
-
使用orm和原生sql的优缺点&#xff1f;
-
简述MVC和MTV
-
django的contenttype组件的作用&#xff1f;
-
谈谈你对restfull 规范的认识&#xff1f;
-
接口的幂等性是什么意思&#xff1f;
-
什么是RPC&#xff1f;
-
Http和Https的区别&#xff1f;
-
为什么要使用django rest framework框架&#xff1f;
-
django rest framework框架中都有那些组件&#xff1f;
-
django rest framework框架中的视图都可以继承哪些类&#xff1f;
-
简述 django rest framework框架的认证流程。
-
django rest framework如何实现的用户访问频率控制&#xff1f;
-
Flask框架的优势&#xff1f;
-
Flask框架依赖组件&#xff1f;
-
Flask蓝图的作用&#xff1f;
-
列举使用过的Flask第三方组件&#xff1f;
-
简述Flask上下文管理流程?
-
Flask中的g的作用&#xff1f;
-
Flask中上下文管理主要涉及到了那些相关的类&#xff1f;并描述类主要作用&#xff1f;
-
为什么要Flask把Local对象中的的值stack 维护成一个列表&#xff1f;
-
Flask中多app应用是怎么完成&#xff1f;
-
在Flask中实现WebSocket需要什么组件&#xff1f;
-
wtforms组件的作用&#xff1f;
-
Flask框架默认session处理机制&#xff1f;
-
解释Flask框架中的Local对象和threading.local对象的区别&#xff1f;
-
Flask中 blinker 是什么&#xff1f;
-
SQLAlchemy中的 session和scoped_session 的区别&#xff1f;
-
SQLAlchemy如何执行原生SQL&#xff1f;
-
ORM的实现原理&#xff1f;
-
DBUtils模块的作用&#xff1f;
- 以下SQLAlchemy的字段是否正确&#xff1f;如果不正确请更正&#xff1a;1234567891011
from
datetime
import
datetime
from
sqlalchemy.ext.declarative
import
declarative_base
from
sqlalchemy
import
Column, Integer, String, DateTime
Base
&#61;
declarative_base()
class
UserInfo(Base):
__tablename__
&#61;
&#39;userinfo&#39;
id
&#61;
Column(Integer, primary_key
&#61;
True
, autoincrement
&#61;
True
)
name
&#61;
Column(String(
64
), unique
&#61;
True
)
ctime
&#61;
Column(DateTime, default
&#61;
datetime.now())
-
SQLAchemy中如何为表设置引擎和字符编码&#xff1f;
-
SQLAchemy中如何设置联合唯一索引&#xff1f;
-
简述Tornado框架的特点。
-
简述Tornado框架中Future对象的作用&#xff1f;
-
Tornado框架中如何编写WebSocket程序&#xff1f;
-
Tornado中静态文件是如何处理的&#xff1f; 如&#xff1a;
-
Tornado操作MySQL使用的模块&#xff1f;
-
Tornado操作redis使用的模块&#xff1f;
-
简述Tornado框架的适用场景&#xff1f;
-
git常见命令作用&#xff1a;
-
简述以下git中stash命令作用以及相关其他命令。
-
git 中 merge 和 rebase命令 的区别。
-
公司如何基于git做的协同开发&#xff1f;
-
如何基于git实现代码review&#xff1f;
-
git如何实现v1.0 、v2.0 等版本的管理&#xff1f;
-
什么是gitlab&#xff1f;
-
github和gitlab的区别&#xff1f;
-
如何为github上牛逼的开源项目贡献代码&#xff1f;
-
git中 .gitignore文件的作用?
-
什么是敏捷开发&#xff1f;
-
简述 jenkins 工具的作用?
-
公司如何实现代码发布&#xff1f;
-
简述 RabbitMQ、Kafka、ZeroMQ的区别&#xff1f;
-
RabbitMQ如何在消费者获取任务后未处理完前就挂掉时&#xff0c;保证数据不丢失&#xff1f;
-
RabbitMQ如何对消息做持久化&#xff1f;
-
RabbitMQ如何控制消息被消费的顺序&#xff1f;
-
以下RabbitMQ的exchange type分别代表什么意思&#xff1f;如&#xff1a;fanout、direct、topic。
-
简述 celery 是什么以及应用场景&#xff1f;
-
简述celery运行机制。
-
celery如何实现定时任务&#xff1f;
-
简述 celery多任务结构目录&#xff1f;
-
celery中装饰器 &#64;app.task 和 &#64;shared_task的区别&#xff1f;
-
简述 requests模块的作用及基本使用&#xff1f;
-
简述 beautifulsoup模块的作用及基本使用&#xff1f;
-
简述 seleninu模块的作用及基本使用?
-
scrapy框架中各组件的工作流程&#xff1f;
-
在scrapy框架中如何设置代理&#xff08;两种方法&#xff09;&#xff1f;
-
scrapy框架中如何实现大文件的下载&#xff1f;
-
scrapy中如何实现限速&#xff1f;
-
scrapy中如何实现暂定爬虫&#xff1f;
-
scrapy中如何进行自定制命令&#xff1f;
-
scrapy中如何实现的记录爬虫的深度&#xff1f;
-
scrapy中的pipelines工作原理&#xff1f;
-
scrapy的pipelines如何丢弃一个item对象&#xff1f;
-
简述scrapy中爬虫中间件和下载中间件的作用&#xff1f;
-
scrapy-redis组件的作用&#xff1f;
-
scrapy-redis组件中如何实现的任务的去重&#xff1f;
-
scrapy-redis的调度器如何实现任务的深度优先和广度优先&#xff1f;
-
简述 vitualenv 及应用场景?
-
简述 pipreqs 及应用场景&#xff1f;
-
在Python中使用过什么代码检查工具&#xff1f;
-
简述 saltstack、ansible、fabric、puppet工具的作用&#xff1f;
-
B Tree和B&#43; Tree的区别&#xff1f;
-
请列举常见排序并通过代码实现任意三种。
-
请列举常见查找并通过代码实现任意三种。
-
请列举你熟悉的设计模式&#xff1f;
-
有没有刷过leetcode&#xff1f;
-
列举熟悉的的Linux命令。
-
公司线上服务器是什么系统&#xff1f;
-
解释 PV、UV 的含义&#xff1f;
-
解释 QPS的含义&#xff1f;
-
uwsgi和wsgi的区别&#xff1f;
-
supervisor的作用&#xff1f;
-
什么是反向代理&#xff1f;
-
简述SSH的整个过程。
-
有问题都去那些找解决方案&#xff1f;
-
是否有关注什么技术类的公众号&#xff1f;
-
最近在研究什么新技术&#xff1f;
-
是否了解过领域驱动模型&#xff1f;
-