阡陌 发表于 2024-2-25 10:27:20

Python 数据类型与条件运算笔记


## 数据类型

整数、浮点数、字符串(单引号、双引号、三引号、r 标记)、布尔值(True、False)、空值(None)、列表、字典、集合、用户自定义数据类型



## 字符串

字符串的单引号、双引号基本没有区别。

str 在内存中是用 Unicode 编码的



### str 与 bytes 转换

用 ecode() 方法转换为 bytes,用 decode() 方法从 bytes 转换为 str

```
>>> 'ABC'.encode('ascii')
b'ABC'
>>> '中文'.encode('utf-8')
b'\xe4\xb8\xad\xe6\x96\x87'
>>> b'\xe4\xb8\xad\xe6\x96\x87'.decode('utf-8')
'中文'
```

注意 b 前缀(表示 bytes)的用法



### 函数方法

ord():获取字符的整数表示

chr():把编码转换为对应的字符

len():获取字符串长度

```
>>> len('中文')
2
>>> len(b'\xe4\xb8\xad\xe6\x96\x87')
6
>>> len('中文'.encode('utf-8'))
6
```



### 字符串格式化

%d、%f、%s、%x

```
>>> 'Hi, %s, you have $%d.' % ('Michael', 1000000)
'Hi, Michael, you have $1000000.'
>>> '%2d-%02d' % (3, 1)
' 3-01'
>>> '%.2f' % 3.1415926
'3.14'
>>> 'Age: %s. Gender: %s' % (25, True)
'Age: 25. Gender: True'(注:%s会把任何数据类型转换为字符串)
```



## 列表(list)

list 是一种有序的集合,可以随时添加和删除其中的元素。

```
>>> classmates = ['Michael', 'Bob', 'Tracy']
>>> classmates
['Michael', 'Bob', 'Tracy']

>>> len(classmates)(注:元素个数)
3

>>> classmates
'Michael'
>>> classmates
'Bob'

>>> classmates[-1](注:倒数第一个元素)
'Tracy'
>>> classmates[-2]
'Bob'

>>> classmates.append('Adam') (注:追加元素到末尾)
>>> classmates
['Michael', 'Bob', 'Tracy', 'Adam']

>>> classmates.insert(1, 'Jack')(注:追加元素到某序号之后)
>>> classmates
['Michael', 'Jack', 'Bob', 'Tracy', 'Adam']

>>> classmates.pop()(注:弹出末尾元素,不要与队列混淆,况且也没有push方法)
'Adam'
>>> classmates
['Michael', 'Jack', 'Bob', 'Tracy']

>>> classmates.pop(1)(注:弹出指定序号元素)
'Jack'
>>> classmates
['Michael', 'Bob', 'Tracy']

>>> classmates = 'Sarah'(注:直接给某元素赋值)
>>> classmates
['Michael', 'Sarah', 'Tracy']
```

**list 里面的元素的数据类型也可以不同**

```
>>> L = ['Apple', 123, True]
```

**list 元素也可以是另一个 list**

```
>>> s = ['python', 'java', ['asp', 'php'], 'scheme']
>>> len(s)
4
>>> s
'php'
```



## 元组(tuple)

tuple 和 list 非常类似,但是 **tuple 一旦初始化就不能修改**,所以,自然也没有 append()、insert() 这样的方法。

可以近似地理解为常量数组。

```
>>> classmates = ('Michael', 'Bob', 'Tracy')
>>> classmates
('Michael', 'Bob', 'Tracy')

```


只有 1 个元素的 tuple 定义时必须加一个逗号`,`,来消除歧义:

```
>>> t = (1)
>>> t(注:此时t的值是整型数值1,而不是一个元组)
1
>>> t = (1,)
>>> t
(1,)

```



## 字典(dict)

字典在其他语言中也称为 map,使用键-值(key-value)存储,具有极快的查找速度。

为什么 dict 查找速度这么快?因为 dict 的实现原理和查字典是一样的。假设字典包含了 1 万个汉字,我们要查某一个字,一个办法是把字典从第一页往后翻,直到找到我们想要的字为止,这种方法就是在 list 中查找元素的方法,list 越大,查找越慢。另一种方法是先在字典的索引表里(比如部首表)查这个字对应的页码,然后直接翻到该页,找到这个字。无论找哪个字,这种查找速度都非常快,不会随着字典大小的增加而变慢。

```
>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
>>> d['Michael']
95

>>> d['Adam'] = 67 (注:添加新键值对)
>>> d
{'Adam': 67, 'Tracy': 85, 'Michael': 95, 'Bob': 75}


```

key 是否存在

```
>>> 'Thomas' in d
False
>>> d.get('Thomas') (注:返回None)
>>> d.get('Thomas', -1)
-1


```

弹出一个键值对(删除)

```
>>> d.pop('Bob')
75
>>> d
{'Adam': 67, 'Tracy': 85, 'Michael': 95}

```



## 集合(set)

set 和 dict 类似,也是一组 key 的集合,但不存储 value。由于 key 不能重复,所以,在 set 中,没有重复的 key。这就是数学中集合的概念了。

可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

重复元素在 set 中自动被过滤:

```
>>> s = set()
>>> s
{1, 2, 3}
>>> s.add(4)
>>> s
{1, 2, 3, 4}
>>> s.remove(4) (注:删除一个元素,不能使用pop(4))
>>> s
{1, 2, 3}

```

两个集合的交集、并集运算

```
>>> s1 = set()
>>> s2 = set()
>>> s1 & s2
{2, 3}
>>> s1 | s2
{1, 2, 3, 4}


```



## 条件运算

### if ... elif ... else ...

```
age = 3
if age >= 18:
    print('adult')
elif age >= 6:
    print('teenager')
else:
    print('kid')
   
   
if x: (注:只要x是非零数值、非空字符串、非空list等,就判断为True)
    print('True')

```



### for x in ...

```
sum = 0
for x in :
    sum = sum + x
print(sum)

sum = 0
for x in range(1, 11):
    sum = sum + x
print(sum)
```



### while ...

```
sum = 0
n = 1
while n <= 10:
    sum = sum + n
    n += 1
print(sum)
```


页: [1]
查看完整版本: Python 数据类型与条件运算笔记