三. Python基础(3)--语法

时间:2023-03-08 17:14:12
三. Python基础(3)--语法

三. Python基础(3)--语法

1. 字符串格式化的知识补充

tpl = "我是%s,年龄%d,学习进度100%" %('Arroz',18)

print(tpl)

# 会提示:ValueError: incomplete format# 占位符只有格式化时才有意义

 

msg = "我是%s,年龄%d,学习进度100%"

print(msg)

# 结果:我是%s,年龄%d,学习进度100%

 

# 如果想要格式化输出字符串,同时又想要打印%,需要写两个%

msg = "我是%s,年龄%d,学习进度100%%"%("Arroz",19)

print(msg)

,学习进度100%

 

# 字符串格式化的一种写法:

tpl = "我是%s, 年龄%d, 学习进度100%%" % ('Arroz', 19)

print(tpl)

 

判断字符串是否为数值:isdecimal()

 

2. 整数(int)类型

v1 = 15

print(v1.bit_length()) # 4

# 当十进制用二进制表示时,最少使用的位数(excluding the sign and leading zeros)

# bit_length()不能用于字符串类型

 

# bit_length()可用于布尔类型

v2 = True

print(v2.bit_length()) # 1,布尔类型实际上也是数值型

 

v3 = -37

print(bin(v3)) # -0b100101

print(v3.bit_length()) # 6

 

# 也可以写成(-37).bit_length()

# 不能写成-37.bit_length()

 

3. 布尔(bool)类型

整数0和空字符串""相当于False

非0 的整数/浮点数,和非空的字符串相当于True

也就是说while True相当于while "天天向上", while 7, while 4.5, while -4.5等

 

wihle 1的执行时间约为while True的2/3,为什么?

由于Python2中,True、False不是关键字,因此我们可以对其进行任意的赋值,这就导致程序在每次循环时都需要对True。False的值进行检查;而对于1,则被程序进行了优化,而不进行检查。

 


注意:

v = 0 or 6

print(v)

v = 6 or 0

print(v)

v = 2 or 1

print(v)

v = 1 or 2

print(v)

v = 9 or 2 > 3

print(v)

v = 9 or 2 < 3

print(v)

v = 2 > 3 or 9

print(v)

v = 2 < 3 or 9

print(v)

# "逻辑或"的运算原则是从左向右判断, 一旦判断出一个表达式为True, 那么整个逻辑运算的值就是这个表达式的值.

6

6

2

1

9

9

9

True

print("=======")

v = 0 and 6

print(v)

v = 6 and 0

print(v)

v = 2 and 1

print(v)

v = 1 and 2

print(v)

v = 9 and 2 > 3

print(v)

v = 9 and 2 < 3

print(v)

v = 2 > 3 and 9

print(v)

v = 2 < 3 and 9

print(v)

# "逻辑与"的运算原则是从左向右判断, 若有一个表达式为False, 那么整个表达式都为False(或者是代表False的对象), 若几个表达式都为真, 那么整个逻辑运算的值就是最后一个表达式的值.

0

0

1

2

False

True

False

 

4. 字符串(str)类型

● 类提供的功能:

① upper()

② lower()

③ capitalize()

④ strip(); lstrip(); rstrip()

⑤ replace()

⑥ split()


变量本身的值不变, 函数返回变化后的值

 

● 公共功能:

①len()

②索引 indexing

③切片 slicing (切片都是"左闭右开"的区间)

string = 'abcdefg'

new_str = string[:4] + string[4]+ string[4:]

print(string, new_str, sep = "→") # abcdefg→abcdeefg

 

5. 列表(list)类型

● 类提供的功能:

①append()

②insert()

 

● 公共功能:

① len()

② 索引(取, 改,删): [], =, del

特殊的: list[0:2] = ["Eric",]

③ 遍历: for

注意下面的案例:

v = ["Peter", "Paul", "Mary", "Harry", "Jerry"]

# v[3] = "Leo" # ['Peter', 'Paul', 'Mary', 'Leo', 'Jerry']

# v[3] = ["Leo",] # ['Peter', 'Paul', 'Mary', ['Leo'], 'Jerry']

# v[3:4] = "Leo" # ['Peter', 'Paul', 'Mary', 'L', 'e', 'o', 'Jerry']

# v[3:4] = ["Leo",] # ['Peter', 'Paul', 'Mary', 'Leo', 'Jerry']

# v[3:5] = ["Leo",] # ['Peter', 'Paul', 'Mary', 'Leo']

# v[3:9] = ["Leo",] # ['Peter', 'Paul', 'Mary', 'Leo'] # 不会提示"list index out of range"

# 如果列表只有一个元素,推荐加上一个逗号

# v[3:5] = "Leo" # ['Peter', 'Paul', 'Mary', 'L', 'e', 'o']

# v[3:9] = "Leo" # ['Peter', 'Paul', 'Mary', 'L', 'e', 'o'] # 不会提示"list index out of range"

# print(v[7]) # 会提示"list index out of range"

del v[3]

del(v[3]) # 一般不这么用, 此时del仍然不是一个函数

v[3].del() # del是语句,不是list的方法


变量本身的值发生变化, 函数返回None

 

6. 元组(Tuple)类型

● 元素不可变(immutable)的容器(container), 但是它内部可以包含可变元素(如列表)

 

● 类提供的功能: 无

 

● 公共功能:

① len()

② 索引(取) :[]

③ 遍历:for

 

7. 字典(dict)类型

● 类提供功能

①get()

get()--如果不存在查询的键, 不报错, 返回关键字'None'

v[键]--如果不存在查询的键, 报错

print(dict["k1"]) # v1

#print(dict["k3"])

print(dict.get("k1")) # v1

print(dict.get("k3")) # None

 

● 字典元素的顺序:

字典元素的书写顺序不是它们实际的存储顺序, 字典将根据每个元素的Hashcode值进行排序.


原因

因为python字典的本质是一个Hash表hash表的数据结构注定它就是无序的。

 

● "键"的要求

1)一个键不允许出现两次。

2) 键必须不可变(也就是hashable),所以可以用数值, 字符串或元组充当键,列表就不行

 

● 公共功能:

①len()

dict = {

    "k1" : "v1",

    "k2" : "v2"

}

print(len(dict)) #2

②索引(取,改,删): =, del

# del dict["k1"]

# print(dict) # {'k2': 'v2'}


由于字典是不排序的,所以不能像列表那样通过切片生成新字典

 

③循环

- for i in dict.keys() # dict_keys(['k1', 'k2'])

- for i in dict.values() # dict_values(['v1', 'v2'])

- for i in dict.items() # dict_items([('k1', 'v1'), ('k2', 'v2')])

 

for i in dict.keys():

    print(i)

# 等价于:

for j in dict:

    print(j)

# 注意, 字典没有切片, 因为字典是无序的.

 

● 案例: 注意下面三种遍历"键-值"对的方法

v = {

    "k1":"v1",

    "k2":"v2"

}

 

for i in v.items():

    print(i)

 

for a,b in v.items():

    print(a, b)

for (a,b) in v.items():

    print(a, b)

('k1', 'v1') # 元组

('k2', 'v2')

k1 v1

k2 v2

k1 v1

k2 v2

 

● 案例

n = input("Your name:")

a = input("Your age:")

user_list = [{"name": "Peter","age": 18}, {"name": "Paul", "age": 19}, {"name": "Mary", "age": 20}]

 

temp ={"name": n, "age": int(a)}

user_list.append(temp)

for item in user_list:

    print(item["name"], item["age"])

    #print(a, b for a, b in item.items())

Your name:Leo

Your age:21

Peter 18

Paul 19

Mary 20

Leo 21

 

8. 强制转换(casting)

int()

float()

str()

bool()

三. Python基础(3)--语法

 

知识补充

● 字面量, 变量

a = 11

注意区分作为字面量(literal)的"11",和作为变量的a,它们在计算机中存储是不一样的。

 

● 在Pycharm中查看文档

 

三. Python基础(3)--语法

三. Python基础(3)--语法

 

● 切片&步长

text = "洞庭湖位于长江中游荆江南岸"

slice = text[1:20:2]# 即使这里的20 > len(text), 也不会提示越界

print(slice)

print(text)

# del text[1:15:2] # 报错, 'str' object does not support item deletion

# print(text)

 

li = [11,22,33,44,55,66]

del li[1:15:2] # 把奇数索引的元素删去

print(li)