自学Python6个月,你能找到工作吗?

本文分享了一份真实的Python面试题,涵盖了Python数据结构、字符串处理、函数变量作用域、对象拷贝、编码转换、列表操作、参数传递、统计分析、字典排序及代码运行结果解析等内容,旨在帮助读者检验和提升Python编程能力。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自学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 可以分为五个阶段,每个阶段都专注于不同的技能和知识点。通过这种方式,可以确保从基础到高级的全面掌握[^1]。 - **第一阶段:Python 基础** 在这一阶段,需要学习 Python 的基本语法、数据类型、控制流、函数定义等基础知识。这是后续学习的基础[^3]。 - **第二阶段:Python 进阶** 此阶段重点学习面向对象编程(OOP)、模块化编程、异常处理、文件操作等内容。这些知识将帮助你更深入地理解 Python 的核心机制[^1]。 - **第三阶段:Web 开发 - Django 框架与项目实践** 学习 Django 框架的基本使用方法,包括模型、视图、模板以及 URL 配置等内容,并完成一个完整的 Web 项目开发[^1]。 - **第四阶段:Web 开发 - Flask 框架与项目实践** 掌握 Flask 框架的核心概念,如路由、请求处理、模板引擎等,并结合实际案例进行项目开发[^1]。 - **第五阶段:人工智能与数据分析** 学习 NumPy、Pandas、Matplotlib 等库,了解机器学习基础理论并实践深度学习框架 TensorFlow 或 PyTorch 的应用[^1]。 #### 推荐学习资源 - **在线课程** 推荐观看涵盖 Python 必备基础、爬虫和数据分析的 100 多节视频课程,这些课程能够帮助初学者快速入门并逐步进阶[^3]。 - **实战案例** 提供超过 100 个 Python 实战案例,涉及爬虫、数据分析、Web 开发等多个领域,确保学习不仅仅是停留在理论层面。 - **漫画教程** 华为出品的独家 Python 漫画教程适合手机端学习,内容生动有趣且易于理解,是零基础学习者的理想选择[^3]。 - **面试真题** 收集了历年互联网企业 Python 面试真题,包含阿里、腾讯、字节等一线大厂的最新资料,刷完这套面试题有助于找到满意的工作[^4]。 ```python # 示例代码:简单的 Python 函数示例 def greet(name): return f"Hello, {name}!" print(greet("World")) ``` #### 注意事项 学习过程中应避免盲目学习,建议按照明确的学习路线图进行,这样可以构建更加全面的知识体系,同时减少重复学习和无用功[^2]。 ---
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值