2024年Python最全Python基础教程:str、list、numpy分片操作,Python面试数据结构算法

最后

Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

👉Python所有方向的学习路线👈

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

👉Python必备开发工具👈

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

👉Python全套学习视频👈

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

👉实战案例👈

学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。

因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。

👉大厂面试真题👈

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

s[::-1]

‘elcycib’

s[::-2]

‘eccb’

给切片赋值

首先,生成一个长度为16,从0到15的列表

l = list(range(16))

l

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]

用[20,30]将取代索引[2,5)的值

l[2:5] = [20, 30]

l

[0, 1, 20, 30, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]

索引[5,8)将被删除

‘’’

遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025

寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!

‘’’

del l[5:8]

l

[0, 1, 20, 30, 5, 9, 10, 11, 12, 13, 14, 15]

从数组第9个索引开始,以两个单位为间隔,将[11,22]赋值给左边的分片对象,如果赋值数组中元素的个数和分片对象中元素的个数不同,则会报错

l[9::2]

[13, 15]

l[9::2] = [11, 22]

l

[0, 1, 20, 30, 5, 9, 10, 11, 12, 11, 14, 22]

l[6::2]

[10, 12, 14]

l[6::2] = [66, 77, 88] # 同理,l[6::2]必须为[n1,n2,n3]的数组,如果不是则将其 赋值为[66, 77, 88]则会报错

l

[0, 1, 20, 30, 5, 9, 66, 11, 77, 11, 88, 22]

列表l[2:5]的结果是[20, 30, 5],而我们的赋值是[30, 33],所以30会代替20,33会代替30,而5则会被去除。如果左边数组元素的个数少于赋值数组中元素的个数,则原数组分片之后的元素会排在新元素之后

l[2:5]

[20, 30, 5]

l[2:5] = [30, 33]

l

[0, 1, 30, 33, 9, 66, 11, 77, 11, 88, 22]

l[2:5]

[30, 33, 9]

l[2:5] = [-10, -20, -30, -40, -50]

l

[0, 1, -10, -20, -30, -40, -50, 66, 11, 77, 11, 88, 22]

拷贝一个分片对象,并修改其中的值,并不会修改原列表对象中的值

‘’’

遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025

寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!

‘’’

l1 = l[2:5]

l1

[-10, -20, -30]

l1 = [10, 20, 30]

l1

[10, 20, 30]

l

[0, 1, -10, -20, -30, -40, -50, 66, 11, 77, 11, 88, 22]

如果将一个数字赋值给左边的分片对象,则会报错

l[2:5] = 10

Traceback (most recent call last):

File “”, line 1, in

TypeError: can only assign an iterable

numpy基本的索引和切片

import numpy as np

arr = np.arange(10)

arr

array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])

arr[5]

5

arr[5:8]

array([5, 6, 7])

arr[5:8] = 12 # 这里不会像之前会报错

arr

array([ 0, 1, 2, 3, 4, 12, 12, 12, 8, 9])

如上所示,当你将一个标量赋值给一个切片对象时(如arr[5:8] = 12),该值会自动传播到整个选区。跟之前列表的分片的区别在于,numpy数组分片是原始数组的视图,数据没有被复制,视图上任何的修改都会直接反映到源数据上,如果不希望修改到源数据,则用arr[5:8].copy()

‘’’

遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025

寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!

‘’’

arr_slice = arr[5:8]

arr_slice

array([12, 12, 12])

arr_slice[1] = 99

arr_slice

array([12, 99, 12])

arr

array([ 0, 1, 2, 3, 4, 12, 99, 12, 8, 9])

arr_slice[:] = 66

arr

array([ 0, 1, 2, 3, 4, 66, 66, 66, 8, 9])

arr_slice_copy = arr[5:8].copy()

arr_slice_copy

array([66, 66, 66])

arr_slice_copy[:] = 88

arr_slice_copy

array([88, 88, 88])

arr

array([ 0, 1, 2, 3, 4, 66, 66, 66, 8, 9])

在一个二维数组中,各索引位置上的元素不再是标量而是一维数组:

arr2d = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])

arr2d[2]

array([7, 8, 9])

arr2d[0][2]

3

arr2d[0, 2]

3

按照行或者列来进行分片

arr2d

array([[1, 2, 3],

[4, 5, 6],

[7, 8, 9]])

arr2d[:2] # 取前两行,即第0行和第1行

array([[1, 2, 3],

[4, 5, 6]])

arr2d[:2, 1:] # 取前两行的第零列之后所有元素

array([[2, 3],

[5, 6]])

arr2d[:, 1:2] # 取所有行的第一列元素(列索引从0开始)

array([[2],

[5],

[8]])

arr2d[1, :2] # 取第一行的前两列的元素元素

array([4, 5])

arr2d[2, :1] # 取第二行的第零列元素

array([7])

arr2d[:, :1] # 取所有行的第零列元素

array([[1],

[4],

[7]])

arr2d[:, 1:] = 0 # 同样,分片表达式的赋值操作也会扩散到源数据

arr2d

array([[1, 0, 0],

[4, 0, 0],

[7, 0, 0]])

布尔型索引

假设我们有一个用于存储数据的数组以及一个存储姓名的数组(含有重复项)。

import numpy as np

from numpy.random import randint

names = np.array([‘Bob’, ‘Joe’, ‘Bob’, ‘Will’, ‘Will’, ‘Joe’, ‘Joe’, ‘Bob’])

data = randint(6, size=(8, 4))

data

array([[2, 1, 2, 2],

[3, 3, 4, 2],

[0, 5, 3, 5],

[2, 1, 5, 2],

[1, 3, 0, 3],

[0, 0, 0, 1],

[0, 0, 0, 5],

[4, 2, 5, 1]])

假设每个名字都对应data数组中的一行,而我们想要选出对应于名字“Bob”的所有行。我们可以这样操作

names == ‘Bob’

array([ True, False, True, False, False, False, False, True], dtype=bool)

data[names == ‘Bob’]

array([[2, 1, 2, 2],

[0, 5, 3, 5],

[4, 2, 5, 1]])

布尔型数组的长度必须跟被索引的数组长度一致,此外,还可以将布尔型数组跟分片、整数(或整数序列)混合使用

‘’’

遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025

寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!

‘’’

data[names == ‘Bob’, 2:]

array([[2, 2],

[3, 5],

[5, 1]])

data[names == ‘Bob’, 3]

array([2, 5, 1])

data[names == ‘Bob’, 3:]

array([[2],

[5],

[1]])

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值