108 道 Python 面试笔试题超强汇总 - 上部

1、一行代码实现1--100之和?

利用sum()函数求和

sum(range(0, 101))

2、如何在一个函数内部修改全局变量?

利用global 修改全局变量

3、列出5个Python标准库?

☞ Python3 标准库概览 

os提供了不少与操作系统相关联的函数

sys通常用于命令行参数

re正则匹配

math数学运算

datetime处理日期时间

4、字典如何删除键和合并两个字典?

del和update方法

In [1]: dict1 = {"name": "zhangsan", "age": 18}                                                                     

In [2]: dict2 = {"gender": "man", "height": 1.82}                                                                   

In [3]: del dict1["age"]                                                                                           

In [4]: dict1                                                                                                      
Out[4]: {'name': 'zhangsan'}

In [5]: dict1.update(dict2)                                                                                        

In [6]: dict1                                                                                                      
Out[6]: {'gender': 'man', 'height': 1.82, 'name': 'zhangsan'}

5、谈下Python的GIL?

GIL是Python的全局解释器锁,同一进程中假如有多个线程运行,一个线程在运行Python程序的时候会霸占Python解释器(加了一把锁即GIL),使该进程内的其他线程无法运行,等该线程运行完后其他线程才能运行。如果线程运行过程中遇到耗时操作,则解释器锁解开,使其他线程运行。所以在多线程中,线程的运行仍是有先后顺序的,并不是同时进行。

多进程中因为每个进程都能被系统分配资源,相当于每个进程有了一个Python解释器,所以多进程可以实现多个进程的同时运行,缺点是进程系统资源开销大

6、Python实现列表去重的方法?

先通过集合去重,在转列表

In [1]: li = [1, 2, 2, 3, 3, 3]                                                                                    

In [2]: a = set(li)                                                                                                

In [3]: a                                                                                                          
Out[3]: {1, 2, 3}

In [4]: [x for x in a]                                                                                             
Out[4]: [1, 2, 3]

7、fun(*args,**kwargs)中的*args,**kwargs什么意思?

*args和**kwargs主要用于函数定义。你可以将不定数量的参数传递给一个函数。这里的不定的意思是:预先并不知道函数使用者会传递多少个参数给你,所以在这个场景下使用这两个关键字。

*args是用来发送一个非键值对的可变数量的参数列表给-一个函数,这里有个例子帮你理解这个概念:

def demo(a, *args):
    print("输出:")
    print(a)
    print("------")
    print(args)
    print("------")
    for data in args:
        print(data)


demo(1, 2, 3, 4, 5)

"""
输出:
1
------
(2, 3, 4, 5)
------
2
3
4
5
"""

**kwargs允许你将不定长度的键值对,作为参数传递给一个函数。如果你想要在一个函数里处理带名字的参数,你应该使用**kwargs。这里有个例子帮你理解这个概念:

def demo(**kwargs):
    print("输出:")
    for k, v in kwargs.items():
        print(k, v)


demo(name='apollo', gender="man")

"""
输出:
name apollo
gender man
"""

8、Python2和Python3的range(100)的区别?

Python2返回列表,Python3返回迭代器,节约内存。

9、一句话解释什么样的语言能够用装饰器?

函数可以作为参数传递的语言,可以使用装饰器。

10、Python内建数据类型有哪些?

整型   --->   int

布尔型   --->   bool

字符串   --->   str

列表   --->   list

元组   --->   tuple

字典   --->   dict

11、简述面向对象中__init__和__new__区别?

__init__是初始化方法,创建对象后,就立刻被默认调用了,可接收参数,如图

108 道 Python 面试笔试题超强汇总 - 上部_第1张图片

1)__new__至少要有一个参数cls,代表当前类,此参数在实例化时由Python解释器自动识别。

2)__new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类(通过super(当前类名, cls))__new__出来的实例,或者直接是object的__new__出来的实例。

3)__init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作,__init__不需要返回值。

4)如果__new__创建的是当前类的实例,会自动调用__init__函数,通过return语句里面调用的__new__函数的第一个参数是cls来保证是当前类实例,如果是其他类的类名,那么实际创建返回的就是其他类的实例,其实就不会调用当前类的__init__函数,也不会调用其他类的__init__函数。

108 道 Python 面试笔试题超强汇总 - 上部_第2张图片

12、简述with方法打开处理文件帮我我们做了什么?

108 道 Python 面试笔试题超强汇总 - 上部_第3张图片

打开文件在进行读写的时候可能会出现一些异常状况,如果按照常规的f.open写法,我们需要try、except、finally,做异常判断,并且文件最终不管遇到什么情况,都要执行finally f.close()关闭文件,with方法帮我们实现了finally中f.close(当然还有其他自定义功能,有兴趣可以研究with方法源码)。

13、列表[1,2,3,4,5],请使用map()函数输出[1,4,9,16,25],并使用列表推导式提取出大于10的数,最终输出[16,25]?

map()函数第一个参数是fun,第二个参数一般是list,第三个参数可以写list,也可以不写,根据需求。

li = [1, 2, 3, 4, 5]

def func(x):
    return x ** 2

a = map(func, li)
b = [x for x in a if x > 10]
print(b)  # [16, 25]

14、python中生成随机整数、随机小数、0--1之间小数方法?

随机整数:random.randint(a, b),生成区间内的整数

随机小数:习惯用numpy库,利用np.random.randn(5)生成5个随机小数

0-1随机小数:random.random(),括号中不传参

import random
import numpy as np

x = random.randint(1, 20)
print("随机整数:", x)  # 随机整数: 15

x = np.random.randn(5)
print("随机小数:", x)  # 随机小数: [ 0.92587753  0.35187744 -1.96555253  0.33319831 -1.85219944]

x = random.random()
print("0-1随机小数:", x)  # 0-1随机小数: 0.9007093018571225

15、避免转义给字符串加哪个字母表示原始字符串?

r , 表示需要原始字符串,不转义特殊字符

16

中国
,用正则匹配出标签里面的内容(“中国”),其中class的类名是不确定的。

import re

str = '
中国
' ret = re.findall(r'
(.*)
', str) # (.*)提取文本 print(ret) # ['中国']

17、Python中断言方法举例?

assert()方法,断言成功,则程序继续执行,断言失败,则程序报错。

x = 4
assert(x > 2)
print("断言成功,程序继续执行")

assert(x > 8)
print("断言失败,则程序报错")

108 道 Python 面试笔试题超强汇总 - 上部_第4张图片

18、数据表student有id,name,score,city字段,其中name中的名字可有重复,需要消除重复行,请写sql语句?

MySQL复习:MySQL数据库的基本操作、MySQL查询

select distinct name from student

19、10个Linux常用命令?

复习:Linux 的基本命令

ls  pwd  cd  touch  rm  mkdir  tree  cp  mv  cat  more  grep  echo 

20、Python2和Python3区别?列举5个

1、Python3 使用 print 必须要以小括号包裹打印内容,比如 print('hi')

Python2 既可以使用带小括号的方式,也可以使用一个空格来分隔打印内容,比如 print 'hi'

2、Python2 range(1,10)返回列表,python3中返回迭代器,节约内存

3、Python2中使用ascii编码,python中使用utf-8编码

4、Python2中unicode表示字符串序列,str表示字节序列

     Python3中str表示字符串序列,byte表示字节序列

5、Python2中为正常显示中文,引入coding声明,python3中不需要

6、Python2中是raw_input()函数,python3中是input()函数

21、列出python中可变数据类型和不可变数据类型,并简述原理

不可变数据类型:数值型、字符串型string和元组tuple

不允许变量的值发生变化,如果改变了变量的值,相当于是新建了一个对象,而对于相同的值的对象,在内存中则只有一个对象(一个地址),用id()方法可以打印对象的id。

a = 1
b = a
print(id(a))  # 10919424
print(id(b))  # 10919424
b = b + 1
print(id(b))  # 10919456

可变数据类型:列表list和字典dict;

允许变量的值发生变化,即如果对变量进行append、+=等这种操作后,只是改变了变量的值,而不会新建一个对象,变量引用的对象的地址也不会变化,不过对于相同的值的不同对象,在内存中则会存在不同的对象,即每个对象都有自己的地址,相当于内存中对于同值的对象保存了多份,这里不存在引用计数,是实实在在的对象。

list1 = [1, 2]
list2 = list1
print(id(list1))  # 139906662832712
print(id(list2))  # 139906662832712
list2.append(3)
print(id(list2))  # 139906662832712

108 道 Python 面试笔试题超强汇总 - 上部_第5张图片

22、s = "ajldjlajfdljfddd",去重并从小到大排序输出"adfjl"?

set去重,去重转成list,利用sort方法排序,reverse=False是从小到大排。

list是不变数据类型,s.sort时候没有返回值。

s = "ajldjlajfdljfddd"
l = list(s)  # 将字符串转化为列表
x = set(l)  # 将列表转化为集合,目的是去重
l = list(x)  # 再将集合转化为列表
l.sort(reverse=False)  # 进行排序, reverse=False 从小到大排序,是默认状态
s = "".join(l)  # 将列表转化为字符串
print(s)  # adfjl

23、用lambda函数实现两个数相乘?

sum = lambda a, b: a * b  # 函数名 = lambda 参数: 表达式
print(sum(4, 5))  # 20

24、字典根据键从小到大排序?

dict={"name":"zs","age":18,"city":"深圳","tel":"1362626627"}

dict = {"name": "zs", "age": 18, "city": "深圳", "tel": "1362626627"}
list = sorted(dict, key=lambda i: i[0], reverse=False)  # dict的结果为字典的键(key)
print("根据字典键排序的键:", list)  # 根据字典键排序的键: ['age', 'city', 'name', 'tel']
new_dict = {}
for key in list:
    new_dict[key] = dict[key]
print("新字典:", new_dict)
# 新字典: {'age': 18, 'city': '深圳', 'name': 'zs', 'tel': '1362626627'}

sorted 语法:
    sorted(iterable[, cmp[, key[, reverse]]])

参数说明:
    iterable -- 可迭代对象。
    cmp -- 比较的函数,这个具有两个参数,参数的值都是从可迭代对象中取出,此函数必须遵守的规则为,大于则返回1,小于则返回-1,等于则返回0。
    key -- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
    reverse -- 排序规则,reverse = True 降序 , reverse = False 升序(默认)。

返回值:
    返回重新排序的列表。

25、利用collections库的Counter方法统计字符串每个单词出现的次数"kjalfj;ldsjafl;hdsllfdhg;lahfbl;hl;ahlf;h"?

from collections import Counter

str = "kjalfj;ldsjafl;hdsllfdhg;lahfbl;hl;ahlf;h"
res = Counter(str)
print(res)
# Counter({'l': 9, ';': 6, 'h': 6, 'f': 5, 'a': 4, 'j': 3, 'd': 3, 's': 2, 'k': 1, 'g': 1, 'b': 1})

26、字符串a = "not 404 found 张三 99 深圳",每个词中间是空格,用正则过滤掉英文和数字,最终输出"张三  深圳"?

import re

a = "not 404 found 张三 99 深圳"
list = a.split(" ")
ret = re.findall(r"\d+|[a-zA-Z]+", a)  # | 连接多个匹配方式,两边不能有空格
print(ret)  # ['not', '404', 'found', '99']
for data in ret:
    if data in list:
        list.remove(data)
print(list)  # ['张三', '深圳']
new_a = " ".join(list)
print(new_a)  # 张三 深圳

27、filter方法求出列表所有奇数并构造新列表a =  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]?

filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。该接收两个参数,第一个为函数,第二个为序列,序列的每个元素作为参数传递给函数进行判,然后返回 True 或 False,最后将返回 True 的元素放到新列表。

def fn(x):
    return x % 2 == 1

a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
b = filter(fn, a)  # filter()返回值是一个对象 
c = [x for x in b]
print(c)  # [1, 3, 5, 7, 9]

28、列表推导式求列表所有奇数并构造新列表,a =  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]?

a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
b = [x for x in a if x % 2 == 1]
print(b)  # [1, 3, 5, 7, 9]

29、正则re.complie作用?

re.compile是将正则表达式编译成一个对象,加快速度,并重复使用。

30、a=(1,)b=(1),c=("1") 分别是什么类型的数据?

a = (1,)
b = (1)
c = ("1")
print(type(a))  # 
print(type(b))  # 
print(type(c))  # 

31、两个列表[1,5,7,9]和[2,2,6,8]合并为[1,2,2,5,6,7,8,9]?

extend可以将另一个集合中的元素逐一添加到列表中,区别于append整体添加。

a = [1, 5, 7, 9]
b = [2, 2, 6, 8]
a.extend(b)
print(a)  # [1, 5, 7, 9, 2, 2, 6, 8]
a.sort(reverse=False)
print(a)  # [1, 2, 2, 5, 6, 7, 8, 9]

32、用Python删除文件和用linux命令删除文件方法?

python:os.remove (文件名)

linux:rm 文件名

33、log日志中,我们需要用时间戳记录error,warning等的发生时间,请用datetime模块打印当前时间戳 “2018-04-01 11:38:54”?

顺便把星期的代码也贴上了

import datetime

t = datetime.datetime.now()
print(t)  # 2018-11-09 19:06:19.259846
t1 = t.strftime("%Y-%m-%d %H:%M:%S")
print(t1)  # 2018-11-09 19:06:19
w = t.isoweekday()
print(w)  # 5
time = str(t1) + "  星期:" + str(w)
print(time)  # 2018-11-09 19:06:19  星期:5

34、数据库优化查询方法?

外键、索引、联合查询、选择特定字段等等。

详情点击链接 ☞ 数据库优化查询方法总结

35、请列出你会的任意一种统计图(条形图、折线图等)绘制的开源库,第三方也行?

pychart、matplotlib

36、写一段自定义异常代码?

自定义异常用raise抛出异常

# raise 自定义异常
def fn():
    try:
        for i in range(5):
            if i > 2:
                raise Exception("数字大于2")
    except Exception as e:
        print(e)

fn()

37、正则表达式匹配中,(.*)和(.*?)匹配区别?

(.*)是贪婪匹配,会把满足正则的尽可能多的往后匹配。

(.*?)是非贪婪匹配,会把满足正则的尽可能少匹配。

import re

str = 'abcdef'

ret = re.findall(r"(.*)", str)
print("贪婪匹配:", ret)  # 贪婪匹配: ['abcdef']

ret = re.findall(r"(.*?)", str)
print("非贪婪匹配:", ret)  # 非贪婪匹配: ['abc', 'def']

38、简述Django的orm?

ORM,全拼Object-Relation Mapping,意为对象-关系映射。

实现了数据模型与数据库的解耦,通过简单的配置就可以轻松更换数据库,而不需要修改代码,只需要面向对象编程,orm操作本质上会根据对接的数据库引擎,翻译成对应的sql语句,所有使用Django开发的项目无需关心程序底层使用的是MySQL、Oracle、sqlite....,如果数据库迁移,只需要更换Django的数据库引擎即可。

108 道 Python 面试笔试题超强汇总 - 上部_第6张图片

39、[[1,2],[3,4],[5,6]]一行代码展开该列表,得出[1,2,3,4,5,6]?

列表推导式的骚操作 ​ ​ ​

运行过程:for y in a,每个y是[1,2],[3,4],[5,6],for x in y,每个x就是1,2,3,4,5,6,合并后就是结果。

a = [[1, 2], [3, 4], [5, 6]]
new_a = [x for y in a for x in y]
print(new_a)  # [1, 2, 3, 4, 5, 6]

还有更骚的方法,将列表转成numpy矩阵,通过numpy的flatten()方法,代码永远是只有更骚,没有最骚 ​ ​ ​

import numpy as np
a = [[1, 2], [3, 4], [5, 6]]
new_a = np.array(a).flatten().tolist()
print(new_a)  # [1, 2, 3, 4, 5, 6]

40、x="abc",y="def",z=["d","e","f"],分别求出x.join(y)和x.join(z)返回的结果?

join()括号里面的是可迭代对象,x插入可迭代对象中间,形成字符串,结果一致 

x = "abc"
y = "def"
z = ["d", "e", "f"]
m = x.join(y)
n = x.join(z)
print(m)  # dabceabcf
print(n)  # dabceabcf

顺便建议大家学下os.path.join()方法,拼接路径经常用到

41、举例说明异常模块中try except else finally的相关意义?

try..except..else没有捕获到异常,执行else语句。

try..except..finally不管是否捕获到异常,都执行finally语句。

a = 1
b = int(input("请输入一个数字:"))
try:
    x = a / b
except Exception as e:
    print("产生错误:", e)
else:
    print("没有捕获到异常,执行该语句")
finally:
    print("不管是否捕获异常,都执行该语句")

42、Python中交换两个数值?

方法一:(最简单) 

a, b = 1, 2
print("a =", a)  # a = 1
print("b =", b)  # b = 2
a, b = b, a
print("a =", a)  # a = 2
print("b =", b)  # b = 1

方法二:

a = a + b
b = a - b
a = a - b

 方法三:

a = 3  # 0011
b = 6  # 0110
a = a ^ b
"""
    0011
   ^0110
    0101    5
"""
b = b ^ a
"""
    0110
   ^0101
    0011    3
"""
a = a ^ b
"""
    0101
   ^0011
    0110    6
"""
print("a =", a)  # 6
print("b =", b)  # 3

43、举例说明zip()函数用法?

zip()函数在运算时,会以一个或多个序列(可迭代对象)做为参数,返回一个元组的列表。同时将这些序列中并排的元素配对。

zip()参数可以接受任何类型的序列,同时也可以有两个以上的参数;当传入参数的长度不同时,zip能自动以最短序列长度为准进行截取,获得元组。

a = [1, 2]
b = [5, 6]
ret = [i for i in zip(a, b)]
print(ret)  # [(1, 5), (2, 6)]

a = (1, 2)
b = (5, 6)
ret = [i for i in zip(a, b)]
print(ret)  # [(1, 5), (2, 6)]

a = "ab"
b = "xyz"
ret = [i for i in zip(a, b)]
print(ret)  # [('a', 'x'), ('b', 'y')]

44、a="张明 98分",用re.sub,将98替换为100?

import re

a = "张明 98分"
ret = re.sub(r"\d+", "100", a)
print(ret)

45、写5条常用sql语句?

show databases;

show tables;

desc 表名;

select * from 表名;

delete from 表名 where id=5;

update students set gender=0,hometown="北京" where id=5

46、a="hello"和b="你好"编码成bytes类型?

a = "hello"
b = "你好"
a = a.encode()
b = b.encode()
print(a)  # b'hello'
print(b)  # b'\xe4\xbd\xa0\xe5\xa5\xbd'

47、[1,2,3]+[4,5,6]的结果是多少?

两个列表相加,等价于extend。

a = [1, 2, 3]
b = [4, 5, 6]
print(a + b)  # [1, 2, 3, 4, 5, 6]
a.extend(b)
print(a)  # [1, 2, 3, 4, 5, 6]

48、提高Python运行效率的方法?

1、使用生成器,因为可以节约大量内存;

2、循环代码优化,避免过多重复代码的执行;

3、核心模块用Cython  PyPy等,提高效率;

4、多进程、多线程、协程;

5、多个if elif条件判断,可以把最有可能先发生的条件放到前面写,这样可以减少程序判断的次数,提高效率。

49、简述mysql和redis区别?

redis: 内存型非关系数据库,数据保存在内存中,速度快。

mysql:关系型数据库,数据保存在磁盘中,检索的话,会有一定的Io操作,访问速度相对慢。

50、遇到bug如何处理?

1、细节上的错误,通过print()打印,能执行到print()说明一般上面的代码没有问题,分段检测程序是否有问题,如果是js的话可以alert或console.log。

2、如果涉及一些第三方框架,会去查官方文档或者一些技术博客。

3、对于bug的管理与归类总结,一般测试将测试出的bug用teambin等bug管理工具进行记录,然后一条一条进行修改,修改的过程也是理解业务逻辑和提高自己编程逻辑缜密性的方法,也都会收藏做一些笔记记录。

4、导包问题、城市定位多音字造成的显示错误问题。

你可能感兴趣的:(面试题)