python全栈工程师百科_Python全栈工程师(列表、拷贝)

ParisGabriel

感谢 大家的支持  你们的阅读评价就是我最好的更新动力  我会坚持吧排版做的越来越好

每天坚持 一天一篇 点个订阅吧  灰常感谢    当个死粉也阔以

Python人工智能从入门到精通

列表创建函数:

list(可迭代对象)

序列有5种:

star 字符串

list 列表

tuple 元组

bytes   后面讲

bytearray  后面讲

序列运算符:

in 、 not in

>

>=

<

<=

+

*

列表的索引可以增加、删除、修改、列表的元素值

切片赋值:

步长不等于1时切片赋值,赋值运算符的右侧的可迭代对象提供的元素

的个数一定要等于切片切出的片数

del语句:

用于删除列表的元素

del 列表 [索引]

del 列表 [切片]

Python3中常用的序列相关函数:

len(x) 返回序列的长度

max (x) 返回最大元素

min(x)返回序列最小元素

sum(x) 返回序列中所有原素的和

any(x)真值测试,如果列表中有一个值为真返回true

all(x) 真值测试,如果列表中所有值为真返回true

列表的方法(method):

help(list)

[ ]内的参数代表可以省略

方法                       意义

L.index(v [, begin[, end]])        返回对应元素的索引下标, begin:为开始索引,end:为结束索引,当 value 不存在时触发ValueError错误

L.insert(index, obj)         将某个元素插放到列表中指定的位置 index:索引 obj:要插入的元素

L.count(x)             返回列表中元素的个数x:元素

L.remove(x)            从列表中删除第一次出现在列表中的值 x:元素(例如列表内有2个3 删除第一个 依次进行)

L.copy()                复制此列表(只复制一层,不会复制深层对象)

L.append(x)               向列表中追加单个元素 可以追加可迭代对象元素

L.extend(list)              向列表追加另一个列表

L.clear()                清空列表,等同于 L[:] = []

L.sort(reverse=False)         将列表中的元素进行排序,默认顺序按值的小到大的顺序排列

L.reverse()               列表的反转,用来改变原列表的先后顺序

L.pop([index])           删除索引对应的元素,如果不加索引,默认删除最后元素,同时返回删除元素的引用关系(相当于取出元素不归还,可以用变量来接受)

字符串的文本解析方法:

S.split(sep=None)     将字符串使用sep作为分隔符分割字符串,返回分隔后的字符串列表,当不给定参数时,用空白字符作为分隔符分隔

S.join(iterable)      用可迭代对象中的字符串,返回一个中间用S分隔组合的字符串 S=esp 要插入分割链接的字符 iterable:可迭代对象

潜拷贝和深拷贝:

潜拷贝shallow copy:

help(list.copy)

拷贝指在复制过程中,只复制一层变量,不会复制深成变量绑定的对象的复制过程

例如:

>>> L = [3.1,3.2]>>> L1 = [1, 2, L]>>> L2 =L1.copy()>>>L1

[1, 2, [3.1, 3.2]]>>>L2

[1, 2, [3.1, 3.2]]>>> L2[2][0] = 3.14

>>>L1

[1, 2, [3.14, 3.2]]>>>L2

[1, 2, [3.14, 3.2]]

深拷贝 deep copy:

import copy # 导入copy 模块

例如:

L = [3.1, 3.2]

L1 = [1, 2, L]

L2 = L1.deep copy()

L2[2][0] = 3.14

print(L1) #[1, 2, [3.1, 3.2]]

print(L2) #1, 2, [3.14, 3.2]]

深拷贝通常只对可变对象进行复制 ,不可变对象通常不会复制(这里深拷贝需要 import copy中的deepcopy  后面讲)

小结:

L1 = [1, 2, [3.1, 3.2]]

这里只是纯粹的调用关系  可以通过内存地址查看

L2 = L1          # 不拷贝 同时绑定一个对象

L3 = L1.copy()    # 潜拷贝等同于 L3 = L1[:]

import copy

L4 = copy.deepcopy(L1) #深拷贝

列表推导式 list comprehension:

列表推导式是用可迭代对象生成列表的表达式

语法:

[表达式 for 变量 in 可迭代对象]

[表达式 for 变量 in 可迭代对象 if 真值表达式]

说明:

for in 表达式的 if 子句可以省略,省略后将对所有生成的对象进行求值处理

如:生成1~9的平方的列表

L= [x ** 2 for x in range(1,10)]

列表推到式的嵌套:

语法:

L=[表达式

for 变量1 in 可迭代对象1 if 真值表达式1

for 变量2 in 可迭代对象2 if 真值表达式2 ]

OK 今天的练习比较多 但是都很简单  争取把每个题都要理解他的原理 不懂得对照上面的参数进行核对一下就可以

想要入门IT就必须多写多练 写的代码也多 你就越熟练  越熟练经验越多  尝试不同的思路去分析

什么时候写的想吐 什么时候才算会了  我们一起加油

练习:

1.

已知有列表:

L = [3, 5]

1) 用索引和切片等操作,将原列表改变为:

L = [1, 2, 3, 4, 5, 6]

2) 将列表反转,删除最后一个元素后打印此列表

...

print(L) # [6, 5, 4, 3, 2]

答案:

L = [3, 5]

L[:]= range(1, 7)

L[::-1] = range(1, 7)#L[:] = [range(6, 0, -1)]

del L[-1]print(L)

2.

1. 写程序,让用户输入一些整数,当输入-1时结束输入,将这些数存于列表L中

1) 打印用户共输入了几个数?

2) 打印您输入的数的最大数是多少

3) 打印您输入的数的最小数是多少

4) 打印您输入的这些数的平均值是多少?

答案:

L =[]whileTrue:

a= int(input("please input at will integer (input '-1' over):"))if a <0:breakL.append(a)

L.sort()print("you input line number", len(L))print("top1:", L[-1])print("lower1:", L[0])print("average number :", sum(L) / len(L))

3.

1.已知有一个字符串

s = “100, 200, 300, 500, 800”

将其转换为整数的列表存于L列表中

答案:

s = "100,200,300,500,800"L= s.split(",")print(L)

2.生成前40个婓波那契数(fibonacci)

1 1 2 3 5 8 13 .....

要求将这些数字保存在列表中

打印这些数

答案:

L = [1, 1]

a= 1b= 1

whileTrue:

a+=b

b+=a

L+=[a, b]if len(L) > 38:break

print(L)

方法二

L= [1, 1]

a= 1b=0

i=0while i < 40:

a= a +b

b= a -b

L.append(b)

i+= 1

print(L)

4.

L= [1, 3, 2, 1, 6, 4, 2, ......98, 82]

将列表中出现的重复数字存入另一个列表L2中

要求:重复出现多次的数字在L2中只保留一份 (去重)

答案:

L =[]whileTrue:

a= int(input("please input at will integer (input '-1' over):"))if a <0:breakL.append(a)

L2=[]for x inL:if x not inL2:

L2.append(x)print(L)print(L2)

5.

输入多行文字,存入列表中,

每次输入回车后算一行

任意输入多行,当输入回车(即输入空行时结束输入)

1) 按原输入内容在屏幕上输出内容

2) 打印出您共输入了多少行文字

3) 打印出您共输入了多少个字符

答案;

L =[]

i=0whileTrue:

a= input("please input at will string direct Enter over:")if a == "":breaki+=len(a)

L.append(a)for x inL:print(x)print("您共输入的行数:", len(L))print("您共输入的字符:", i)

6.

1. 有字符串"hello"

请用此字符串生成:

'h e l l o' 和 'h-e-l-l-o'

2. 写一个程序,让用户输入很多正整数,当输入小于零的数时结束输入,

1) 打印这些数中最大的一个数

2) 打印这些数中第二大的一个数

3) 删除最小的一个数

4) 打印剩余数的和

答案:

s = "heool"L= " ".join(s)print(L)

L= "-".join(s)print(L)

7.

用列表推导式生成1~100内奇数的列表

结果是: [1, 3, 5, 7, ..... 99]

答案:

L = [x for x in range(1, 100, 2)]print(L)

L = [x for x in range(1, 100) if x % 2 !=0]print(L)

8.

生成一个数值为 1 ~ 9的平方的列表,去掉所有的奇数的平方

答案:

L = [x**2 for x in range(2, 10, 2)]print(L)

L = [x**2 for x in range(2, 10) if x % 2 ==0]print(L)

Python人工智能从入门到精通

加油!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值