一份真实的Python面试题

来自:googpy(微信号:googpy),作者:stormwen


阅读文本大概需要 9 分钟。

自学Python已有一段时间了,就想着找份面试题来检验一下自己的学习情况,今天就和大家分享一份自己从网上找到的货真价实的Python面试题,每道题目看似简单,但如果基础知识不牢固,很容易回答不全面。


1. python 常用数据结构有哪些?请简要介绍一下。


答:Python中常见的数据结构可以统称为容器(container)。序列(如列表和元组)、映射(如字典)以及集合(set)是三类主要的容器。所以,Python常用数据结构有:列表、字典、元组、集合


关于这个问题,一般也会顺带问:Python中哪些数据类型是可变的,哪些是不可变的?


答:可变/不可变是针对该对象所指向的内存中的值是否可变来判断的。如可变类型的数据类型有:列表、字典、集合;不可变类型的数据类型有:字符串、元组、数字


2. 简要描述 Python 中单引号、双引号、三引号的区别。


答:首先,单引号和双引号在使用时基本上没有什么区别;


唯一需要注意的是:

  • 当字符串中有单引号时,最好在外面使用双引号;

  • 当有双引号时,最好在外面使用单引号;

  • 三引号一般不常用,除了用来做注释外,还可以用来打印多行字符串。特殊用途,是可以打印多行字符串。


3. 如何在一个 function 里面设置一个全局的变量?


答:全局变量是指定义在函数外部的变量。全局变量的作用域为全局。

局部变量是指定义在函数内部的变量。局部变量的作用域为函数内,除了函数就无效了。


例如:


num = 100
def func():
   global num
   num = 200
   num += 100
   print(num)

func()
print(num)

300
300



总结:如果要在函数中给全局变量赋值,需要用global关键字声明。


4. Python 里面如何拷贝一个对象?(赋值、浅拷贝、深拷贝的区别)


答:赋值是将一个对象的地址赋值给一个变量,让变量指向该地址(旧瓶装旧酒

浅拷贝就是对引用的拷贝

深拷贝是对对象的资源的拷贝


举例说明:

(1)


a = ['hello',[1,2,3]]
b = a[:]

print([id(x) for x in a])
print([id(x) for x in b])

a[0] = 'world'
a[1].append(4)
print(a)
print(b)

[34305224, 33841800]
[34305224, 33841800]
['world', [1, 2, 3, 4]]
['hello', [1, 2, 3, 4]]


浅拷贝是在另一块地址中创建一个新的变量或容器,但是容器内的元素的地址均是源对象的元素的地址的拷贝。也就是说新的容器中指向了旧的元素(新瓶装旧酒)。


(2)


from copy import deepcopy
a = ['hello',[1,2,3]]
b = deepcopy(a)

print([id(x) for x in a])
print([id(x) for x in b])

a[0] = 'world'
a[1].append(4)
print(a)
print(b)


[30766280, 30785352]
[30766280, 31727688]
['world', [1, 2, 3, 4]]
['hello', [1, 2, 3]]


深拷贝是在另一块地址中创建一个新的变量或容器,同时容器内的元素的地址也是新开辟的,仅仅是值相同而已,是完全的副本。也就是说(新瓶装新酒)。


总 结


(1)当对象为不可变类型时,不论是赋值,浅拷贝还是深拷贝,那么改变其中一个值时,另一个都是不会跟着变化的。


(2)当对象为可变对象时,如果是赋值和浅拷贝,那么改变其中任意一个值,那么另一个会跟着发生变化的;如果是深拷贝,是不会跟着发生改变的。


5. 如果 custname 字符串的内容为 utf-8 的字符,如何将 custname 的内容转为 gb18030 的字符串?


答:先将custname编码格式转换为unicode,再转换为gb18030。即custname.decode(‘utf-8’).encode(‘gb18030’)。


6. 请写出一段 Python 代码实现删除一个 list 里面的重复元素。


答:方法(一)利用集合set的特性,元素是非重复的


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

def fun1(a):
   a = list(set(a))
   print(a)

fun1(a)

[1, 2, 3, 4, 5]


方法(二)利用字典的fromkeys来自动过滤重复值


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

def fun1(a):
   b = {}
   b = b.fromkeys(a)
   c = list(b.keys())
   print(c)

c = fun1(a)


7. 这两个参数是什么意思:*args,**kwargs?


答:首先,*args和**kwargs并不是必须这样写,只有前面的*和**才是必须的,你可以写成*var和**vars。


其次,*args和**kwargs主要用于函数定义,你可以将不定量的参数传递给一个函数。


其中,*args是用来发送一个非键值对的可变数量的参数列表给一个函数;


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


8. 统计如下 list 单词及其出现次数。


a=['apple''banana''apple''tomato''orange''apple''banana''watermeton']


答:我能想到的最简单的方法就是用collection库


from collections import Counter

a = ['apple', 'banana', 'apple', 'tomato', 'orange', 'apple', 'banana', 'watermeton']
b = Counter(a)
print(b)

Counter({'apple': 3, 'banana': 2, 'tomato': 1, 'orange': 1, 'watermeton': 1})


9. 给列表中的字典排序:假设有如下 list 对象


alist=[{"name":"a""age":20}, {"name":"b""age":30}, {"name":"c""age":25}]


将 alist 中的元素按照 age 从大到小排序。


答:利用list的内置函数sort来进行排序


alist=[{"name":"a", "age":20}, {"name":"b", "age":30}, {"name":"c", "age":25}]
alist.sort(key=lambda x:x['age'])
print(alist)

[{'name': 'a', 'age': 20}, {'name': 'c', 'age': 25}, {'name': 'b', 'age': 30}]


10. 写出下列代码的运行结果


a = 1
def fun(a):
  a = 2
fun(a)
print(a)


a = []
def fun(a):
  a.append(1)
fun(a)
print(a)


class Person:
    name = 'Lily'

p1 = Person()
p2 = Person()
p1.name = 'Bob'
print(p1.name)
print(p2.name)
print(Person.name)


答:第一段代码的运行结果为:1

第二段代码的运行结果为:[1]

第三段代码的运行结果为:


Bob

Lily

Lily


11. 假设有如下两个 list:a = ['a', 'b', 'c', 'd', 'e'],b = [1, 2, 3, 4, 5],将 a 中的元素作为 key,b 中元素作为 value,将 a,b 合并为字典。

答:


a = ['a','b','c','d','e']
b = [1,2,3,4,5]
c = dict(zip(a,b))
print(c)



总结


通过做这份真实的面试题,我发现自己对一些知识掌握的比较模糊,基础知识还有待进一步的,导致对一些问题回答的还不够全面。


最后,我觉得这也是一种学Python的好方法呀,可以不断检验自己的学习情况,督促自己不断进步。


小伙伴们,你们做对了几道呀?欢迎留言交流Python学习。

推荐↓↓↓
Python编程
上一篇:爬虫工程师都在用的爬虫利器,你知道吗? 下一篇:用Python制作恋爱日志