一份真实的Python面试题

阅读文本大概需要 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学习。

原文发布于微信公众号 - googpy(googpy)

原文发表时间:2019-06-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券