# python工程师面试题

Python基础语法相关

一、Python中的pass语句的作用是什么?
pass语句什么也不做,一般作为占位符 或者创建站位程序,pass语句不会不执行任何操作。
二、Python是如何进行类型转换的
python提供了将变量或值从一种类型转换为另一种类型的内置函数。比如int函数能将符合数学格式数字型字符串转换为整型。否则,返回错误信息。
三、Python是如何进行内存管理的?
Python引用了一个内存池(memory pool)机制,即Pymalloc机制(malloc:n.分配内存),用于管理对小块内存的申请和释放。
四、dict的items()方法与iteritems()方法的不同
items方法将所有的字典以列表方式放回,其中项在放回时没有特殊的顺序;
iteritems方法有相似的作用,但是反回一个迭代器对象。
五、什么是lambda函数?它有什么好处?
编程中提到的lambda表达式,通常是在需要一个函数,但是又想费神去命名一个函数的场合下使用,也就是指匿名函数。
Python允许你定义一种单行的小函数。定义lambda函数的形式:lambda 参数:表达式lambda函数默认返回表达式的值。你也可以将其赋值给一个变量。lambd函数可以接受任意参数,包括可选参数,但是表达式只有一个。
六、说明os,sys模块不同,并列举常用的模块方法?
os:提供一种方便的使用操作系统函数的方法。
sys:提供访问由解释器使用或维护的变量和在与解释器交互使用到的函数。
os常用的方法
在这里插入图片描述
sys常用的方法
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200630110712702.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80ODk5NDE2Mw==,size_16,color_FFFFFF,t_70

七、Python里面如何拷贝一个对象?deepcopy和copy的区别?

copy仅拷贝对象本身,而不拷贝对象中引用的其它对象。
deepcopy除拷贝对象本身,而且拷贝对象中引用的其它对象。

八、os.path和sys.path的区别?

os.path是module,包含了各种处理长文件名(路径名)的函数。
sys.path是由目录名构成的列表,Python从中查找扩展模块(Python源模块,编译模块,或者二进制扩展).启动Python时,这个列表从根据内建规则,PYTHONPATH环境变量的内容,,以及注册表(windows系统)等进行初始化。

九、re模块中match和search方法的不同?

match()函数只检查RE是否在字符串开始处匹配,而search()则是扫描整个字符串。

十、解释生成器(generator)与函数的不同,并实现和使用简单generator?

生成器和函数的主要区别在与函数return avalue,生成器yield value同时标记或记忆point of the yield以便于在下次调用时从标记点恢复执行。yield使用函数转换生成器,而生成器反过来又返回迭代器。

十一、Python Web相关

解释一下 WSGI 和 FastCGI 的关系?
CGI全称是“公共网关接口”(CommonGateway Interface),HTTP服务器与你的或其它机器上的程序进行“交谈”的一种工具,其程序须运行在网络服务器上。 CGI可以用任何一种语言编写,只要这种语言具有标准输入、输出和环境变量。如php,perl,tcl等。

FastCGI像是一个常驻(long-live)型的CGI,它可以一直执行着,只要激活后,不会每次都要花费时间去fork一次(这是CGI最为人诟病的fork-and-execute模式)。它还支持分布式的运算, 即 FastCGI 程序可以在网站服务器以外的主机上执行并且接受来自其它网站服务器来的请求。

FastCGI是语言无关的、可伸缩架构的CGI开放扩展,其主要行为是将CGI解释器进程保持在内存中并因此获得较高的性能。众所周知,CGI解释器的反复加载是CGI性能低下的主要原因,如果CGI解释器保持在内存中并接受FastCGI进程管理器调度,则可以提供良好的性能、伸缩性、Fail- Over特性等等。

WSGI的全称为: PythonWeb Server Gateway Interface v1.0 (Python Web 服务器网关接口),

它是 Python 应用程序和 WEB 服务器之间的一种接口。

它的作用,类似于FCGI 或 FASTCGI 之类的协议的作用。

WSGI 的目标,是要建立一个简单的普遍适用的服务器与 WEB 框架之间的接口。

Flup就是使用 Python 语言对 WSGI 的一种实现,是可以用于 Python 的应用开发中的一种工具或者说是一种库。

Spawn-fcgi是一个小程序,这个程序的作用是管理fast-cgi进程,那么管理wsgi进程也是没有问题的,功能和php-fpm类似。

故,简单地说,WSGI和FastCGI都是一种CGI,用于连接WEB服务器与应用程序,而WSGI专指Python应用程序。而flup是WSGI的一种实现,Spawn-fcgi是用于管理flup进程的一个工具,可以启动多个wsgi进程,并管理它们。

十二、解释一下 Django 和 Tornado 的关系、差别

Django源自一个在线新闻 Web站点,于 2005 年以开源的形式被释放出来。

Django 框架的核心组件有:

用于创建模型的对象关系映射为最终用户设计的完美管理界面一流的 URL 设计设计者友好的模板语言缓存系统等等

它鼓励快速开发,并遵循MVC设计。Django遵守 BSD版权,最新发行版本是Django

1.4,于2012年03月23日发布.Django的主要目的是简便、快速的开发数据库驱动的网站。它强调代码复用,多个组件可以很方便的以“插件”形式服务于整个框架,Django有许多功能强大的第三方插件,你甚至可以很方便的开发出自己的工具包。这使得Django具有很强的可扩展性。它还强调快速开发和DRY(Do Not RepeatYourself)原则。

Tornado是 FriendFeed使用的可扩展的非阻塞式 web 服务器及其相关工具的开源版本。这个 Web 框架看起来有些像 web.py 或者 Google 的 webapp,不过为了能有效利用非阻塞式服务器环境,这个 Web 框架还包含了一些相关的有用工具和优化。

Tornado 和现在的主流 Web 服务器框架(包括大多数Python 的框架)有着明显的区别:它是非阻塞式服务器,而且速度相当快。得利于其 非阻塞的方式和对epoll的运用,Tornado 每秒可以处理数以千计的连接,这意味着对于实时 Web服务来说,Tornado 是一个理想的 Web 框架。我们开发这个 Web 服务器的主要目的就是为了处理 FriendFeed 的实时功能 ——在 FriendFeed 的应用里每一个活动用户都会保持着一个服务器连接。(关于如何扩容 服务器,以处理数以千计的客户端的连接的问题。
十三、解释下django-debug-toolbar的使用

使用django开发站点时,可以使用django-debug-toolbar来进行调试。在settings.py中添加’debug_toolbar.middleware.DebugToolbarMiddleware’到项目的MIDDLEWARE_CLASSES 内。

十四、解释下Django使用redis缓存服务器

为了能在Django中使用redis,还需要安装redis for Django的插件。然后在Django的settings中配置了。现在连接和配置都已经完成了,接下来是一个简单的例子:
在这里插入图片描述
十五、执行目录下所有的测试(所有的test.py文件):运行测试的时候,测试程序会在所有以test开头的文件中查找所有的test cases(inittest.TestCase的子类),自动建立测试集然后运行测试。*
$ python manage.py test

执行animals项目下tests包里的测试:

$ python manage.py testanimals.tests

执行animals项目里的test测试:

$ python manage.py testanimals

单独执行某个test case:

$ python manage.py testanimals.tests.AnimalTestCase

单独执行某个测试方法:

$ python manage.py testanimals.tests.AnimalTestCase.test_animals_can_speak

为测试文件提供路径:

$ python manage.py testanimals/

$ python manage.py test–pattern=“tests_*.py”

启用warnings提醒:

$ python -Wall manage.py test

十六、解释下Http协议
HTTP是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。

**十七、HTTP协议的主要特点可概括如下:
**在这里插入图片描述
十八、解释下Http请求头和常见响应状态码
Accept:指浏览器或其他客户可以接爱的MIME文件格式。可以根据它判断并返回适当的文件格式。

Accept-Charset:指出浏览器可以接受的字符编码。英文浏览器的默认值是ISO-8859-1.

Accept-Language:指出浏览器可以接受的语言种类,如en或en-us,指英语。

Accept-Encoding:指出浏览器可以接受的编码方式。编码方式不同于文件格式,它是为了压缩文件并加速文件传递速度。浏览器在接收到Web响应之后先解码,然后再检查文件格式。

Cache-Control:设置关于请求被代理服务器存储的相关选项。一般用不到。

Connection:用来告诉服务器是否可以维持固定的HTTP连接。HTTP/1.1使用Keep-Alive为默认值,这样,当浏览器需要多个文件时(比如一个HTML文件和相关的图形文件),不需要每次都建立连接。

Content-Type:用来表名request的内容类型。可以用HttpServletRequest的getContentType()方法取得。

Cookie:浏览器用这个属性向服务器发送Cookie。Cookie是在浏览器中寄存的小型数据体,它可以记载和服务器相关的用户信息,也可以用来实现会话功能。

十九、状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值:
1xx:指示信息–表示请求已接收,继续处理

2xx:成功–表示请求已被成功接收、理解、接受

3xx:重定向–要完成请求必须进行更进一步的操作

4xx:客户端错误–请求有语法错误或请求无法实现

5xx:服务器端错误–服务器未能实现合法的请求

常见状态代码、状态描述、说明:

200 OK //客户端请求成功

400 Bad Request //客户端请求有语法错误,不能被服务器所理解

401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用

403 Forbidden //服务器收到请求,但是拒绝提供服务

404 Not Found //请求资源不存在,eg:输入了错误的URL

500 Internal Server Error //服务器发生不可预期的错误

503 Server Unavailable //服务器当前不能处理客户端的请求,一段时间后可能恢复正常

以下是一些Python工程师面试真题及其答案: 1.请尽可能列举python列表的成员方法,并给出列表操作的答案: ```python a = [1, 2, 3, 4, 5] # append()方法:在列表末尾添加新元素 a.append(6) print(a) # 输出:[1, 2, 3, 4, 5, 6] # extend()方法:在列表末尾添加另一个列表中的所有元素 b = [7, 8, 9] a.extend(b) print(a) # 输出:[1, 2, 3, 4, 5, 6, 7, 8, 9] # insert()方法:在指定位置插入新元素 a.insert(0, 0) print(a) # 输出:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] # remove()方法:删除列表中的指定元素 a.remove(0) print(a) # 输出:[1, 2, 3, 4, 5, 6, 7, 8, 9] # pop()方法:删除列表中指定位置的元素,并返回该元素的值 a.pop(0) print(a) # 输出:[2, 3, 4, 5, 6, 7, 8, 9] # index()方法:返回列表中指定元素的索引值 print(a.index(2)) # 输出:0 # count()方法:返回列表中指定元素的出现次数 print(a.count(2)) # 输出:1 # sort()方法:对列表进行排序 a.sort() print(a) # 输出:[2, 3, 4, 5, 6, 7, 8, 9] # reverse()方法:将列表中的元素倒序排列 a.reverse() print(a) # 输出:[9, 8, 7, 6, 5, 4, 3, 2] ``` 2.请介绍一下Python中的装饰器是什么,以及如何使用它们? 装饰器是Python中的一种高级语法,它允许在不修改原始函数代码的情况下,向函数添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返回一个新的函数。使用装饰器可以实现很多功能,例如日志记录、性能分析、输入验证等。以下是一个简单的装饰器示例: ```python def my_decorator(func): def wrapper(): print("Before the function is called.") func() print("After the function is called.") return wrapper @my_decorator def say_hello(): print("Hello!") say_hello() ``` 输出: ``` Before the function is called. Hello! After the function is called. ``` 3.请介绍一下Python中的生成器是什么,以及如何使用它们? 生成器是Python中的一种特殊类型的函数,它可以在需要时生成一个值序列,而不是一次性生成所有值。生成器使用yield语句来生成值,而不是return语句。生成器可以节省内存,并且可以在处理大量数据时提高性能。以下是一个简单的生成器示例: ```python def my_generator(): yield 1 yield 2 yield 3 for value in my_generator(): print(value) ``` 输出: ``` 1 2 3 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值