Python基础
1.说一说你所知道的 Python 数据结构有哪些。
list
tuple
dict
set
str
int
float
bool
2.Python 中列表和元组的区别是什么?元组是不是真的不可变?
列表可变,元组不可变
元组的查询速度比列表快
列表能进行增删改查操作,元组不可以进行增加操作
列表不可以作为字典的键,元组可以作为字典的键
3.什么是生成器和迭代器?它们之间有什么区别?
生成器:生成器包括列表生成器和函数中加入yield生成器
生成器并不是列表,它保存了如何生成生成器中元素的算法
解决了列表或者是列表生成式的缺点,解决了大量无用数据占用资源的问题
生成器中含有游标,记录了元素的位置,下次使用数据时,会继续去取数据
迭代器:
通过调用__next__()方法能不断生成下一个数据的方式,就是迭代器
4.什么是闭包?装饰器又是什么?装饰器有什么作用?你用过装饰器吗?请写一个装饰器的例子。
闭包:
闭包需要满足3个条件:
函数中嵌套函数
内部函数中调用外部函数中的变量
外部函数要返回内部函数中的函数名
内部函数不能修改外部函数中变量,如果非要修改用关键字nolocal
装饰器:
不改变原函数的功能,增加新的功能
在使用装饰器的方法上加@函数名或者类名
装饰器分为函数装饰器和类装饰器
5 什么是 lambda 函数? 有什么好处?
lambda 函数是一个可以接收任意多个参数(包括可选参数)并且返回单个表达式值的函数
lambda 函数比较轻便,即用即仍,很适合需要完成一项功能,但是此功能只在此一处使用,连名字都很随意的情况下
匿名函数,一般用来给 filter, map 这样的函数式编程服务
作为回调函数,传递给某些应用,比如消息处理
6.在学习 Python 的过程中,你有想过如何提高 Python 的运行效率吗?
if elif … else:语句中,尽量把执行几率高的语句放到最上面,减少代码的执行
for、while循环语句中,尽量减少代码的循环测试
不定义列表或者列表生成式,采用列表生成器,减少内存中无用数据的堆积
采用多线程,异步方式执行
减少不必要的代码执行
减少不必要的IO操作
7.用过类吗?知道继承吗?请写一个例子,用到继承。
match() 如果在字符串的开头有0个或更多个字符,符合正则表达式模式,返回相关匹配的实例对象;如果字符串不符合正则表达式模式则返回None;
而search()则不同,扫描整个字符串,如果产生了一个匹配正则模式就寻找到这个位置,返回相关匹配的对象。如果没有位置能够匹配这个模式则返回None。
import restr="谢谢您的关注和支持:YZL40514131"result=re.match('40514131',str)result1=re.match('谢您',str)result2=re.match('谢谢您',str)print(result)Noneprint(result1)Noneprint(result2)<re.Match object; span=(0, 3), match='谢谢您'>
import restr="谢谢您的关注和支持:YZL40514131"result3=re.search('14131',str)print(result3)<re.Match object; span=(16, 21), match='14131'>result4=re.search('141310',str)print(result4)None
Django
1.什么是 Django? 说说你的理解。
2.Django 遵循什么样的设计模式?每个字母代表什么意思?各自完成什么样的功能?它和MVC是怎么对应的?
MVC:模型类、视图、控制器
运行顺序:
客户端传输数据,控制器接收数据,进行处理
与模型类进行映射,与数据库进行交互
将数据返回到控制器
再将数据传到视图函数中
视图函数将数据进行封装成一个响应
再交给控制器
控制器返回给客户端
MVT:模型类、视图、模板
3.Django 中的缓存是怎么用的?
我采用的是redis进行数据缓冲的
a、安装:pip install django-redis
b、settings.py文件中配置:
c、在指定的视图函数加上装饰器 @cache_page(10, cache='default', key_prefix='mysite')
d、请求视图,redis中生成缓冲数据
4.用 Django 做过什么项目吗?大概是怎么样的思路?现在让你写个登陆页面,你要怎么写?
自动化接口平台,
步骤:
安装user子应用:
python manage.py startapp user
注册
user子应用
安装第三方应用:pip install gjango-restframework-jwt
settings.py文件中配置
定义路由:
主路由:path('user/',include('users.urls'))
子路由:path('login/', obtain_jwt_token),
访问路由:http://127.0.0.1:8000/user/login
登录成只返回了token,现在需要返回用户名和用户id
在公共文件中重写jwt_response_payload_handler()方法
详细步骤在:
https://blog.csdn.net/YZL40514131/article/details/125840482?spm=1001.2014.3001.5501
5.说一下 session 和 cookie 区别。为什么 cookie 是不安全的?
cookie保存在客户端,由服务端生成的;当用户从客户端访问服务端时,若要记录客户端状态,服务端会给客户端发送一个令牌,客户端下次请求服务端的时候会携带cookie参数,服务端来验证cookie的准确性
session保存在服务端,随着用户认证数量的增多,服务端的开销会明显增大。
拓展性变差;用户认证成功后,服务器保存认证记录,这意味着用户下次请求还必须要请求这台服务器上,这样才能拿到授权的资源,这样在分布式的应用上,相应的限制了负载均衡的能力,也意味着限制了应用的拓展能力
6.你在用 Django 做项目的时候碰到过什么问题吗?你印象最深的是哪个? 你是怎么解决的?
异步任务celery
7 列举django orm 中所有的方法(QuerySet对象的所有方法)
8 谈谈你对restful规范的认识?
1、restful是一种风格,并不是规范或者约束;每一种uri代表一种资源,资源是从数据库中获取的一种集合,所以采用名称的复数形式
例如获取列表资源地址:https://api.example.com/v1/sources
例如获取详情资源地址:https://api.example.com/v1/sources/1
2、HTTP动词:
GET(SELECT):从服务器取出资源(⼀项或多项)。
POST(CREATE):在服务器新建⼀个资源。
PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)。
DELETE(DELETE):从服务器删除资源。
3、过滤信息
” />在多线程程序中,死锁问题很大一部分原因是由于线程同时获取多个锁造成的。
在线程间共享多个资源的时候,如果两个线程分别占有一部分资源并且同时等待对方的资源,就会造成死锁。
尽管死锁很少发生,但是一旦发生就会造成线程的停止工作
死锁类型:
a、没有释放锁
b、多次调用自己
如何预防死锁
让多个线程交叉有序的竞争多个资源
让互斥锁变为逻辑锁
mutex_TianTang=threading.Lock():互斥锁
mutex_TianTang=threading.RLock():互斥锁
2.学过编译原理吗?会用吗?(了解)
编译原理就是将高级语言翻译成计算机语言(即计算机所能识别的二进制代码)所遵循的规律,并且让你理解机器是如何理解高级语言的。
3.用过 Linux 吗?会用吗?在上面搭过环境吗?说一下常用的指令。
cat file
head -n file
tail -n file
tail -f file
tar -cvf log.tar ./
tar -xvf log.tar
tar -czvf log.tar.gz ./
tar -xzvf log.tar.gz
find ./ -name ‘*.log’
ps -aux | grep ‘mysql’
kill -9 进程号
netstat -lt
systemctl status firewalld.service
systemctl stop firewalld.service
vi 编辑命令
su root 切换用户命令
chomd 777 file
grep
sed
awk