Python核心编程总结(一、基础概念与语法)(1)

str2 = ‘[1, 2, 3]’

str3 = ‘(1000, 2000, 3000)’

print(type(eval(str1))) # <class ‘int’>

print(type(eval(str2))) # <class ‘list’>

print(type(eval(str3))) # <class ‘tuple’>

1.7、运算符


  • 算数运算符

  • 赋值运算符

  • 复合赋值运算符

  • 比较运算符

  • 逻辑运算符

1.7.1、算数运算符

| 运算符 | 描述 | 实例 |

| :-: | :-: | — |

| + | 加 | 1 + 1 = 2 |

| - | 减 | 1 - 1 = 0 |

| * | 乘 | 2 * 2 =4 |

| / | 除 | 10 / 2 = 5 |

| // | 整除 | 9 // 4 =2 |

| % | 取余 | 9 % 4 = 1 |

| ** | 指数 | 2 ** 4 = 16 |

| () | 括号 | 用来提高运算优先级 |

混合运算优先级顺序:() 高于 ** 高于 * / // % 高于 + -

1.7.2、赋值运算符

| 运算符 | 描述 | 实例 |

| — | — | — |

| = | 赋值 | 将 = 右侧的结果赋值给等号左侧的变量 |

  • 单个变量赋值

num = 1

print(num)

  • 多个变量赋值

num1, float1, str1 = 10, 0.5, ‘hello world!’

print(num1) # 10

print(float1) # 0.5

print(str1) # hello world!

  • 多个变量赋相同的值

a = b = 10

print(a) # 10

print(b) # 10

1.7.3、复合赋值运算符

| 运算符 | 描述 | 实例 |

| — | — | — |

| += | 加法赋值运算符 | c +=a 等价于 c = c + a |

| -= | 减法赋值运算符 | c -=a 等价于 c = c - a |

| *= | 乘法赋值运算符 | c *=a 等价于 c = c * a |

| /= | 除法赋值运算符 | c /=a 等价于 c = c / a |

| //= | 整除赋值运算符 | c //=a 等价于 c = c // a |

| %= | 取余赋值运算符 | c %=a 等价于 c = c % a |

| **= | 幂赋值运算符 | c ** =a 等价于 c = c ** a |

a = 100

a += 1

输出101 a = a + 1,最终a = 100 + 1

print(a)

b = 2

b *= 3

输出6 b = b * 3,最终b = 2 * 3

print(b)

c = 10

c += 1 + 2

输出13, 先算运算符右侧1 + 2 = 3, c += 3 , 推导出c = 10 + 3

print©

1.7.4、比较运算符

比较运算符也叫关系运算符,通常用来判断

| 运算符 | 描述 | 实例 |

| — | — | — |

| == | 判断相等,如果两个操作数的结果相等,则条件结果为

真True,否则条件结果为假False | 如a=3,b=3,则(a == b) 为True |

| != | 不不等于 。如果两个操作数的结果不不相等,则条件为

真(True),否则条件结果为假(False) | 如a=3,b=3,则(a == b) 为 True如

a=1,b=3,则(a != b) 为 True |

| > | 运算符左侧操作数结果是否⼤大于右侧操作数结果,

如果大于,则条件为真,否则为假 | 如a=7,b=3,则(a > b) 为 True |

| < | 运算符左侧操作数结果是否⼩小于右侧操作数结果,

如果小于,则条件为真,否则为假 | 如a=7,b=3,则(a < b) 为 False |

| >= | 运算符左侧操作数结果是否⼤大于等于右侧操作数结

果,如果大于,则条件为真,否则为假 | 如a=7,b=3,则(a < b) 为 False如

a=3,b=3,则(a >= b) 为 True |

| <= | 运算符左侧操作数结果是否⼩小于等于右侧操作数结

果,如果小于,则条件为真,否则为假 | 如a=3,b=3,则(a <= b) 为 True |

a = 7

b = 5

print(a == b) # False

print(a != b) # True

print(a < b) # False

print(a > b) # True

print(a <= b) # False

print(a >= b) # True

1.7.5、逻辑运算符

| 运算符 | 逻辑表达式 | 描述 | 实例 |

| — | — | — | — |

| and | x and y | 布尔"与":如果 x 为 False,x and y 返回

False,否则它返回 y 的值。 | True and False, 返回

False。 |

| or | x or y | 布尔"或":如果 x 是 True,它返回 True,否则

它返回 y 的值。 | False or True, 返回

True。 |

| not | not | 布尔"非":如果 x 为 True,返回 False 。如果 x

为 False,它返回 True。 | not True 返回 False, not

False 返回 True |

a = 1

b = 2

c = 3

print((a < b) and (b < c)) # True

print((a > b) and (b < c)) # False

print((a > b) or (b < c)) # True

print(not (a > b)) # True

1.7.6、数字之间的逻辑运算

a = 0

b = 1

c = 2

and运算符,只要有一个值为0,则结果为0,否则结果为最后一个非0数字

print(a and b) # 0

print(b and a) # 0

print(a and c) # 0

print(c and a) # 0

print(b and c) # 2

print(c and b) # 1

or运算符,只有所有值为0结果才为0,否则结果为第一个非0数字

print(a or b) # 1

print(a or c) # 2

print(b or c) # 1

1.8、IF


1.8.1、if…else…

  1. 如果用户年龄大于等于18岁,即成年,输出"已经成年,可以上网"

input接收的是字符串,需要转换为整型

age = int(input(“请输入您的年龄:”))

if age >= 18:

print(f"您的年龄为{age},成年可以上网")

else:

print(f"您的年龄为{age},未成年无法上网")

注意:与 java 语言不同的是, if、else、while、for 后面都需要加 冒号:

1.8.1、if…elif…

  1. 中国合法工作年龄为18-60岁,如果年龄小于18的情况为童工,不合法;如果年龄在18*-60岁之间,则为合法工龄;大于60岁为法定退休年龄

input接收的是字符串,需要转换为整型

age = int(input(“请输入您的年龄:”))

if age < 18:

print(f"您的年龄小于18,不能进行工作,属于童工")

elif 18 <= age <= 60:

age >= 18 and age <= 60

print(f"您的年龄为合法年龄,可以工作")

elif age > 60:

print(f"您的年龄不属于合法工作年龄")

1.8.2、IF嵌套

  1. 坐公交:如果有钱可以上车,没钱不能上车,上车后如果有空座,可以坐下,如果没空座,则要站着,怎么书写程序。

money = 1

seat = 0

if money == 1:

print(“有钱,请上车”)

if seat == 1:

print(“有座位,请坐”)

else:

print(“没座位,不能坐”)

else:

print(“没钱,不能上车”)

  1. 猜拳游戏

玩家手动出拳,电脑随机出拳

导入random模块

import 模块名

使用random模块中的随机整数功能

random.randint(开始,结束)

random.randint(0,2)

“”"

提示:0-石头,1-剪刀,2-布

1.出拳

玩家输入出拳

电脑随机出拳

2.判断输赢

玩家获胜

平局

电脑获胜

“”"

导入random模块

import random

计算电脑出拳的随机数字

computer = random.randint(0, 2)

玩家出拳

player = int(input(“请玩家出拳: 0–石头,1–剪刀,2–布”))

玩家胜利 p0,c1 p1,c2 p2,c0

if((player0) and (computer1) or ((player1) and (computer2)) or ((player2) and (computer0))):

print(f"玩家出拳是{player}")

print(f"电脑出拳是{computer}")

print(“玩家获胜”)

elif player==computer:

print(f"玩家出拳是{player}")

print(f"电脑出拳是{computer}")

print(“平局”)

else:

print(f"玩家出拳是{player}")

print(f"电脑出拳是{computer}")

print(“电脑获胜”)

1.8.3、三目运算符

a = 1

b = 2

c = a if a>b else b

print©

条件成立执行的表达式 if 条件 else 条件不成立执行的表达式

1.9、循环


1.9.1、while

  1. 计算1-100的累加和

i = 1

sum = 0

while i <= 100:

sum += i

i += 1

print(sum)

  1. 计算1-100的偶数累加和

①:可以加入判断是否为偶数,对2取余

方法一:条件判断和对2取余数为0则累加计算

i = 1

sum = 0

while i <= 100:

if i %2 ==0:

sum += i

i += 1

print(sum)

方法二:计数器控制增量为2

i = 0

sum = 0

while i <= 100:

sum += i

i += 2

print(sum)

1.9.2、break

  • 作用:终止此循环

i = 1

while i <= 5:

if i ==4:

print(f’吃饱了不吃了’)

break

print(f’吃了第{i}个苹果’)

i +=1

1.9.3、continue

  • 作用:退出当前一次循环继而执行下一次循环代码

i = 1

while i <= 5:

if i == 3:

print(f’大虫子,第{i}个不吃了’)

在 continue 之前一定要修改计数器,否则会陷入死循环

i += 1

continue # continue 退出此次循环,后面的代码就不会执行,i就不会+1

print(f’吃了第{i}个苹果’)

i +=1

1.9.4、while 循环嵌套

  1. 打印星号(正方形)

分析:一行输出5个星号,重复打印5行

“”"

1.打印一个星星*

2.一行5个 循环 — 打印一个星星的代码 ,不换行

3.打印5行 循环–一行五个的代码

“”"

j = 0

while j < 5:

一行星星开始

i = 0

while i< 5:

print(“*” , end=" ")

i += 1

#一行星星结束:换行显示下一行

#这里借助空的print,利用print默认结束符换行

print()

j += 1

  1. 打印星号(三角形)

分析:一行输出星星的个数和行数是相等的,每行:重复打印行号数字个星号,将打印行星号的命令重复执行5次实现打印5行

重复打印5行星星

j表示行号

j = 0

while j <=4:

一行星星的打印、

i = 0

i 表示每行里面星星的个数,这个数字要和行号相等所以 i要和j联动

while i<=j:

print(‘*’,end=‘’)

i +=1

print()

j +=1

  1. 打印99乘法表

重复打印9行表达式

j = 1

while j <= 9:

打印一行里面的表达式 a * b = a *b

i = 1

while i <= j:

print(f’{i}{j}={ji}‘,end=’\t’)

i +=1

print()

j +=1

1.9.5、for循环

for 临时变量 in 序列

重复执行的代码1

重复执行的代码2

str1 = ‘itheima’

for i in str1:

print(i)

#i

#t

#h

#e

#i

#m

#a

1.9.6、while…else…

循环可以和else配合使用,else下方缩进的代码指的是当循环正常结束之后要执行的代码。

while 条件:

条件成立重复执行的代码

else:

循环正常结束之后执行的代码

i = 1

while i <= 5:

print(“老师,我错了!”)

i +=1

else:

print(“我何错之有?”)

所谓 else 指的是循环正常结束之后要执行的代码,即如果是 break 终止循环的情况,else 下方缩进的代码将不执行。

1.9.7、for…else…

for 临时变量 in 序列:

重复执行的代码

else:

循环正常结束后要执行的代码

所谓 else 指的是循环正常结束之后要执行的代码,即如果是 break 终止循环的情况,else 下方缩进的代码将不执行。

1.9.8、总结:

  1. break退出整个循环

  2. continue退出本次循环,继续执行下一次重复执行的代码

  3. while 和 for 都可以配合else使用

  4. else 下方缩进的代码含义:当循环正常结束后执行的代码

  5. break终止循环不会执行else下方缩进的代码

  6. continue 退出循环的方式执行else下方缩进的代码

2、字符串

=======================================================================

  • 双引号,单引号均可修饰字符串

a = “TOM”

b = ‘tom’

  • 三引号字符串

e=‘’'i

am TOM ‘’’

三引号形式的字符串支持换行

  • 创建字符串:I’m Tom

c = “I’m Tom”

d = ‘I’m Tom’

  • 字符串输出

print(‘hello world’)

name = ‘Tom’

print(‘我的名字是%s’ % name)

print(f’我的名字是{name}')

2.1、下标


  • 字符串name="abcdef" ,取到不同下标对应的数据

name = “abcdef”

print(name[1]) # b

print(name[0]) # a

print(name[2]) # c

下标从 0 开始

2.2、切片


作用:对操作对象截取其一部分的操作,字符串,列表,元组都支持切片操作

语法:

序列[开始位置下标:结束位置下标:步长]

  1. 不包含结束位置下标对应的数据,正负整数均可(即截取部分为左闭右开

  2. 步长是选取间隔,正负整数均可,默认步长为1

name = “abcdefg”

print(name[2:5:1]) #cde

print(name[2:5]) #cde

print(name[:5]) #abcde

print(name[1:]) #abcdefg

print(name[:]) #abcdefg

print(name[::2]) #aceg

print(name[:-1]) #abcdef -1表示倒数第一个数据

print(name[-4:-1]) #def

print(name[::-1]) #gfedcba

2.3、字符串查找


字符串的常用操作方法有查找、修改和判断三大类

所谓字符串查找方法即是查找子串在字符串中的位置或出现的次数

2.3.1、find()

find():检测某个字串是否包含在这个字符串中,如果在,返回这个字串开始的位置下标,否则返回-1

字符串序列.find(子串,开始位置下标,结束位置下标)

  • 注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找

mystr =“hello world and itcast and itheima and python”

print(mystr.find(‘and’)) #返回12,helloworld为9,两个空格为2

print(mystr.find(‘and’,15,30)) #返回23,找到第二个’and’

print(mystr.find(‘ands’)) #返回-1,没有这个子串

2.3.2、index()

index():检测某个字串是否包含在这个字符串中,如果在返回这个字串开始的位置下标,否则报异常

字符串序列.index(子串,开始位置下标,结束位置下标)

  • 注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找

mystr =“hello world and itcast and itheima and python”

print(mystr.index(‘and’)) #12

print(mystr.find(‘and’,15,30)) #返回23,找到第二个’and’

print(mystr.find(‘ands’)) #没有这个子串,报错

  • rfind():和find()功能相同,但查找方向从右侧开始

  • rindex():和index()功能相同,但查找方向从右侧开始

2.3.3、count()

count():返回某个子串在字符串中出现的次数

字符串序列.count(子串,开始位置下标,结束位置下标)

  • 注意:开始位置和结束位置下标省略,表示在整个字符串中查找

mystr =“hello world and itcast and itheima and python”

print(mystr.count(‘and’)) #3

print(mystr.count(‘ands’)) #0

print(mystr.count(‘and’),0,20) #1

2.4、字符串修改


所谓修改字符串,指的是通过函数的形式修改字符串中的数据

2.4.1、replace() 替换

字符串序列.replace(旧子串,新子串,替换次数)

  1. 如果替换次数不写,默认替换整个字符串

  2. replace函数有返回值,返回值是修改后的字符串

  3. 调用replace函数,原有字符串数据并没有修改,修改后的数据是replace函数的返回值

  4. 字符串属于不可变类型

  5. 替换次数如果超出子串出现次数,则替换次数为该子串出现次数

mystr =“hello world and itcast and itheima and python”

将 and 替换为 he

new_str=mystr.replace(‘and’,‘he’)

print(new_str)

结果:hello world he itcast he itheima he Python

print(mystr.replace(‘and’, ‘he’, 1))

结果:hello world he itcast and itheima and python

注意:数据按照是否能直接修改分为可变类型和不可变类型。字符串类型的数据修改的时候不能改变原有字符串,属于不能直接修改数据的类型即是不可变类型。

2.4.2、split() 分割

按照指定字符分割字符串

字符串序列.split(分割字符,num)

num表示的是分割字符出现的次数,即将来返回数据个数为 num+1 个。

mystr =“hello world and itcast and itheima and python”

list1 = mystr.split(‘and’)

print(list)

#结果:['hello world ', ’ itcast ', ’ itheima ‘, ’ Python’]

list2 = mystr.split(‘and’,2)

print(list2)

结果:['hello world ', ’ itcast ‘, ’ itheima and Python’]

print(mystr.split(’ '))

结果:[‘hello’, ‘world’, ‘and’, ‘itcast’, ‘and’, ‘itheima’, ‘and’, ‘Python’]

print(mystr.split(’ ', 2))

结果:[‘hello’, ‘world’, ‘and itcast and itheima and Python’]

注意:如果分割字符是原有字符串中的子串,分割后则丢失该子串

2.4.3、join() 合并

join():⽤⼀个字符或子串合并字符串,即是将多个字符串合并为⼀个新的字符串。

字符或子串.join(多字符串组成的序列)

list1 = [‘chuan’, ‘zhi’, ‘bo’, ‘ke’]

print(‘_’.join(list1))

结果:chuan_zhi_bo_ke

t1 = (‘aa’, ‘b’, ‘cc’, ‘ddd’)

print(‘…’.join(t1))

结果:aa…b…cc…ddd

2.4.4、capitalize()

capitalize():将字符串第⼀个字符转换成⼤写。

mystr = “hello world and itcast and itheima and Python”

print(mystr.capitalize())

结果:Hello world and itcast and itheima and python

注意:capitalize()函数转换后,只字符串第⼀个字符⼤写,其他的字符全都⼩写

2.4.5、title()

title():将字符串每个单词首字母转换成大写。

mystr = “hello world and itcast and itheima and Python”

print(mystr.title())

结果:Hello World And Itcast And Itheima And Python

2.4.6、lower()

lower():将字符串中大写转小写。

mystr = “hello world and itcast and itheima and Python”

print(mystr.lower())

结果:hello world and itcast and itheima and python

2.4.7、upper()

upper():将字符串中小写转大写。

mystr = “hello world and itcast and itheima and Python”

print(mystr.upper())

HELLO WORLD AND ITCAST AND ITHEIMA AND PYTHON

2.4.8、lstrip()

lstrip(): 删除字符串左侧空白字符

mystr = " hello world and itcast and itheima and Python"

print(mystr.lstrip())

#结果:hello world and itcast and itheima and python

2.4.9、rstrip()

rstrip(): 删除字符串右侧空白字符

2.4.10、strip()

strip(): 删除字符串两侧空白字符

mystr = " hello world and itcast and itheima and Python "

print(mystr.strip())

#结果:hello world and itcast and itheima and Python

2.4.11、ljust()

ljust():返回一个原字符串左对齐,并使用指定字符(默认空格)填充至对应长度的新字符串

字符串序列.ljust(长度,填充字符)

mystr = ‘hello’

print(mystr.ljust(10))

hello

print(mystr.ljust(10,‘.’))

hello…

  • rjust(): 返回一个原字符串右对齐,并使用指定字符(默认空格)填充至对应长度的新字符串

  • center():返回一个原字符串剧中对齐,并使用指定字符(默认空格)填充至对应长度的新字符串

2.5、字符串判断


所谓判断即是判断真假,返回的结果是布尔型数据类型:True 或 False

2.5.1、startswith()

startswith(): 检查字符串是否是以指定子串开头,是则返回True,否则返回False。如果设置开始和结束位置下标,则在指定范围内检查

字符串序列.startswith(子串,开始位置的下标,结束位置的下标)

mystr = "hello world and itcast and itheima and Python "

print(mystr.startswith(‘hello’))

#结果为:True

print(mystr.startswith(‘hello’, 5, 20))

#结果为:False

2.5.2、endswith()

endswith():检查字符串是否是以指定子串结尾,是则返回True,否则返回False。如果设置开始和结束位置下标,则在指定范围内检查。

mystr = “hello world and itcast and itheima and Python”

结果:True

print(mystr.endswith(‘Python’))

结果:False

print(mystr.endswith(‘python’))

结果:False

print(mystr.endswith(‘Python’, 2, 20))

2.5.3、isalpha()

isalpha():如果字符串⾄少有⼀个字符并且所有字符都是字母则返回 True, 否则返回 False

mystr1 = ‘hello’

mystr2 = ‘hello12345’

结果:True

print(mystr1.isalpha())

结果:False

print(mystr2.isalpha())

2.5.4、isdigit()

isdigit():如果字符串只包含数字则返回True否则返回False

mystr1 = ‘aaa12345’

mystr2 = ‘12345’

结果: False

print(mystr1.isdigit())

结果:False

print(mystr2.isdigit())

2.5.5、isalnum()

isalnum():如果字符串至少有一个字符并且所有字符都是字母或数字则返回True,否则返回False

mystr1 = ‘1 2 3 4 5’

mystr2 = ’ ’

结果:False

print(mystr1.isspace())

结果:True

print(mystr2.isspace())

3、列表

======================================================================

格式:

[数据1,数据2,数据3,数据4…]

列表可以一次性存储多个数据,且可以为不同数据类型,我们可以对这些数据进行的操作有:增、删、改、查

3.1、查找


3.1.1、通过下标

name_list = [‘Tom’,‘Lily’,‘Rose’]

print(name_list[0]) #Tom

print(name_list[1]) #Lily

print(name_list[2]) #Rose

3.1.2、通过函数

  1. index():返回指定数据所在位置的下标 。

列表序列.index(数据,开始位置下标,结束位置下标)

name_list = [‘Tom’,‘Lily’,‘Rose’]

print(name_list.index(‘Lily’,0,2)) #1

  • 注意:如果查找的数据不存在则报错
  1. count(): 统计指定数据在当前列表中出现的次数

name_list = [‘Tom’,‘Lily’,‘Rose’]

print(name_list.count(‘Lily’)) #1

  1. len(): 访问列表长度,即列表中数据的个数

name_list = [‘Tom’,‘Lily’,‘Rose’]

print(len(name_list)) #3

3.1.3、判断是否存在

in: 判断指定数据在某个列表序列,如果在返回True,否则返回False

name_list = [‘Tom’,‘Lily’,‘Rose’]

print(‘Lily’ in name_list)

#结果: True

print(‘Lilys’ in name_list)

#结果: False

**not in:**判断指定数据不在某个列表序列,如果不在返回True,否则返回False

需求:查找用户输入的名字是否已经存在

name_list = [‘TOM’,‘Lily’,‘Rose’]

name = input(‘请输入您要搜索的名字:’)

if name in name_list:

print(f’您输入的名字是{name},名字已经存在’)

else:

print(f’您输入的名字是{name},名字不存在’)

3.2、增加


3.2.1、append()

append(): 列表结尾追加数据

列表序列.append(数据)

name_list = [‘Ton’,‘Lily’,‘Rose’]

name_list.append(‘xiaoming’)

print(name_list)

结果:[‘Tom’, ‘Lily’, ‘Rose’, ‘xiaoming’]

列表追加数据的时候,直接在原列表里面追加了指定数据,即修改了原列表,故列表为可变类型数据

name_list = [‘Ton’,‘Lily’,‘Rose’]

name_list.append([‘xiaoming’, ‘xiaohong’])

结果:[‘Tom’, ‘Lily’, ‘Rose’, [‘xiaoming’, ‘xiaohong’]]

print(name_list)

结果:[‘Tom’, ‘Lily’, ‘Rose’, [‘xiaoming’, ‘xiaohong’]]

  • 注意:如果append()追加的数据是一个序列,则追加整个序列到列表

3.2.2、extend()

extend(): 列表结尾追加数据,如果数据是一个序列,则将这个序列的数据逐一添加到列表。

  1. 单个数据

name_list = [‘Ton’,‘Lily’,‘Rose’]

name_list.extend(‘xiaoming’)

print(name_list)

结果:[‘Tom’, ‘Lily’, ‘Rose’, ‘x’, ‘i’, ‘a’, ‘o’, ‘m’, ‘i’, ‘n’, ‘g’]

  1. 序列数据

name_list = [‘Tom’, ‘Lily’, ‘Rose’]

name_list.extend([‘xiaoming’, ‘xiaohong’])

print(name_list)

结果:[‘Tom’, ‘Lily’, ‘Rose’, ‘xiaoming’, ‘xiaohong’]

3.2.3、insert()

insert() : 指定位置新增数据

列表序列.insert(位置下标,数据)

name_list = [‘Tom’, ‘Lily’, ‘Rose’]

name_list.insert(1.‘xiaoming’)

print(name_list)

结果:[‘Tom’, ‘xiaoming’, ‘Lily’, ‘Rose’]

3.3、删除


3.3.1、del

del 目标

  1. 删除列表

name_list = [‘Tom’, ‘Lily’, ‘Rose’]

del name_list

print(name_list)

已经删除,打印会报错

  1. 删除指定数据

name_list = [‘Tom’, ‘Lily’, ‘Rose’]

del name_list[0]

print(name_list)

结果:[‘Lily’, ‘Rose’]

3.3.2、pop()

pop(): 删除指定下标的数据(默认为最后一个),并返回该数据

列表序列.pop(下标)

name_list = [‘Tom’, ‘Lily’,‘Rose’]

del_name = name_list.pop(1)

print(del_name)

Lily

print(name_list)

#[‘Tom’,‘Rose’]

  1. 如果不指定下标,默认删除最后一个数据

  2. 无论是按照下标,还是删除最后一个,Pop函数都会返回这个被删除的数据,需要进行接收

3.3.3、remove()

remove(): 移除列表中某个数据的第一个匹配项。

列表序列.remove(数据)

name_list = [‘Tom’, ‘Lily’,‘Rose’]

name_list.remove(‘Rose’)

print(name_list)

结果: [‘Tom’,‘Lily’]

3.3.4、clear()

clear():清空列表

name_list = [‘Tom’,‘Lily’,‘Rose’]

name_list.claer()

print(name_list)

结果: []

3.4、修改


修改指定的下标数据

name_list = [‘Tom’,‘Lily’,‘Rose’]

name_list[0] = ‘aaa’

print(name_list)

结果:[‘aaa’,‘Lily’,‘Rose’]

3.4.1、reverse()

reverse():逆置

name_list = [1,5,2,3,6,8]

num_list.reverse()

print(num_list)

结果:[8,6,3,2,5,1]

3.4.2、sort()

sort(): 排序

列表序列.sort( key = None,reverse = False)

  • 注意:reverse表示排序规则,reverse = True 降序,reverse = False 升序(默认)

name_list = [1,5,2,3,6,8]

num_list.sort()

print(num_list)

结果: [1,2,3,5,6,8]

3.5、复制


3.5.1、copy()

name_list = [‘Tom’,‘Lily’,‘Rose’]

name_li2 = name_list.copy()

print(name_li2)

#结果:[‘Tom’,‘Lily’,‘Rose’]

3.6、列表的循环遍历


3.6.1、while

name_list = [‘Tom’,‘Lily’,‘Rose’]

i = 0

while i< len(name_list):

print(name_list[i])

i +=1

‘’’

Tom

Lily

Rose

‘’’

3.6.2、for

name_list = [‘Tom’,‘Lily’,‘Rose’]

for i in name_list:

print(i)

‘’’

Tom

Lily

Rose

‘’’

3.7、列表的嵌套


所谓列表嵌套指的是一个列表里面包含了其他的子列表

应用场景:要存储班级⼀、⼆、三个班级学⽣生姓名,且每个班级的学⽣生姓名在一个列表。

name_list = [[‘小明’, ‘小红’, ‘小绿’], [‘Tom’, ‘Lily’, ‘Rose’], [‘张三’, ‘李四’, ‘王五’]]

#如何找到’李四’

第⼀步:按下标查找到李四所在的列表

print(name_list[2]) # [‘张三’, ‘李四’, ‘王五’]

第⼆步:从李四所在的列表⾥⾯,再按下标找到数据李四

print(name_list[2][1]) # 李四

4、元组

======================================================================

思考:如果想要存储多个数据,但是这些数据是不能修改的数据,怎么做?

答:列表?列表可以一次性存储多个数据,但是列表中的数据允许更改。需要使用元组。

num_list = [10, 20, 30]

num_list[0] = 100

一个元组可以存储多个数据,元组内的数据是不能修改的

4.1、定义元组


元组特点: 定义元组使用小括号,且逗号隔开各个数据,数据可以是不同的数据类型。

多个数据元组

t1 = (10,20,30)

单个数据元组

t2 = (10,)

注意:如果定义的元组只有⼀个数据,那么这个数据后面也要添加逗号,否则数据类型为唯⼀的这个数据的数据类型

t2 = (10,)

print(type(t2)) # tuple

t3 = (20)

print(type(t3)) # int

t4 = (‘hello’)

print(type(t4)) # str

4.2、查找


元组数据不支持修改,只支持查找,具体如下

4.2.1、按下标查找数据

tuple1 = (‘aa’,‘bb’,‘cc’,‘dd’)

print(tuple[0])

aa

4.2.2、index()

index():查找某个数据,如果数据存在返回对应的下标,否则报错,语法和列表、字符串的 index 方法相同

tuple1 = (‘aa’,‘bb’,‘cc’,‘dd’)

print(tuple.index(‘aa’))

0

4.2.3、count()

count():统计某个数据在当前元组出现的次数

tuple1 = (‘aa’,‘bb’,‘cc’,‘bb’)

print(tuple.count(‘bb’))

2

4.2.4、len()

len():统计元组中数据的个数

tuple1 = (‘aa’,‘bb’,‘cc’,‘dd’)

print(len(tuple))

4

注意:元组内的直接数据如果修改则立即报错

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)

se

‘’’

3.6.2、for

name_list = [‘Tom’,‘Lily’,‘Rose’]

for i in name_list:

print(i)

‘’’

Tom

Lily

Rose

‘’’

3.7、列表的嵌套


所谓列表嵌套指的是一个列表里面包含了其他的子列表

应用场景:要存储班级⼀、⼆、三个班级学⽣生姓名,且每个班级的学⽣生姓名在一个列表。

name_list = [[‘小明’, ‘小红’, ‘小绿’], [‘Tom’, ‘Lily’, ‘Rose’], [‘张三’, ‘李四’, ‘王五’]]

#如何找到’李四’

第⼀步:按下标查找到李四所在的列表

print(name_list[2]) # [‘张三’, ‘李四’, ‘王五’]

第⼆步:从李四所在的列表⾥⾯,再按下标找到数据李四

print(name_list[2][1]) # 李四

4、元组

======================================================================

思考:如果想要存储多个数据,但是这些数据是不能修改的数据,怎么做?

答:列表?列表可以一次性存储多个数据,但是列表中的数据允许更改。需要使用元组。

num_list = [10, 20, 30]

num_list[0] = 100

一个元组可以存储多个数据,元组内的数据是不能修改的

4.1、定义元组


元组特点: 定义元组使用小括号,且逗号隔开各个数据,数据可以是不同的数据类型。

多个数据元组

t1 = (10,20,30)

单个数据元组

t2 = (10,)

注意:如果定义的元组只有⼀个数据,那么这个数据后面也要添加逗号,否则数据类型为唯⼀的这个数据的数据类型

t2 = (10,)

print(type(t2)) # tuple

t3 = (20)

print(type(t3)) # int

t4 = (‘hello’)

print(type(t4)) # str

4.2、查找


元组数据不支持修改,只支持查找,具体如下

4.2.1、按下标查找数据

tuple1 = (‘aa’,‘bb’,‘cc’,‘dd’)

print(tuple[0])

aa

4.2.2、index()

index():查找某个数据,如果数据存在返回对应的下标,否则报错,语法和列表、字符串的 index 方法相同

tuple1 = (‘aa’,‘bb’,‘cc’,‘dd’)

print(tuple.index(‘aa’))

0

4.2.3、count()

count():统计某个数据在当前元组出现的次数

tuple1 = (‘aa’,‘bb’,‘cc’,‘bb’)

print(tuple.count(‘bb’))

2

4.2.4、len()

len():统计元组中数据的个数

tuple1 = (‘aa’,‘bb’,‘cc’,‘dd’)

print(len(tuple))

4

注意:元组内的直接数据如果修改则立即报错

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-Xdq9iFtr-1713672897770)]

[外链图片转存中…(img-NktEy4gT-1713672897771)]

[外链图片转存中…(img-WEHxhxrn-1713672897772)]

[外链图片转存中…(img-upCHQrrW-1713672897772)]

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值