python数据类型详解

主要内容:

  1. 列表、元组操作
  2. 字符串操作
  3. 字典操作
  4. 集合操作
  5. 文件操作
  6. 字符编码与转码
列表与元组

定义列表

1 list = [‘a‘ , ‘b‘, ‘c‘, ‘d‘]

通过下标访问列表中的元素,下标从0开始计数

1 list[0] # ‘a‘
2 list[1] # ‘b‘
3 list[-1] # ‘d‘
4 list[-2] # ‘c‘

基本操作:

切片:取多个元素

 1 list = ["A","B","C","D","E","F"]
 2 names[1:4]  #取下标1至下标4之间的数字,包括1,不包括4
 3 #[‘B‘, ‘B‘, ‘D‘]
 4 names[1:-1] #取下标1至-1的值,不包括-1
 5 #[‘B‘, ‘C‘, ‘D‘, ‘E‘]
 6 names[0:3]
 7 #[‘A‘, ‘B‘, ‘C‘]
 8 names[:3] #如果是从头开始取,0可以忽略,跟上句效果一样
 9 #[‘A‘, ‘B‘, ‘C‘]
10 names[3:] #如果想取最后一个,必须不能写-1,只能这么写
11 #[‘D‘, ‘E‘, ‘F‘]
12 names[3:-1] #这样-1就不会被包含了
13 #[‘D‘, ‘E‘]
14 names[0::2] #后面的2是代表,每隔一个元素,就取一个
15 #[‘A‘, ‘C‘, ‘E‘]
16 names[::2] #和上句效果一样
17 #[‘A‘, ‘C‘, ‘E‘] 

追加

names = [‘A‘, ‘B‘, ‘C‘, ‘D‘, ‘E‘, ‘F‘]
names.append("我是新来的")
names = [‘A‘, ‘B‘, ‘C‘, ‘D‘, ‘E‘, ‘F‘,‘我是新来的‘]

插入

1 names=[‘Alex‘, ‘Tenglan‘, ‘Eric‘, ‘Rain‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]
2 names.insert(2,"强行从Eric前面插入")
3 names=[‘Alex‘, ‘Tenglan‘, ‘强行从Eric前面插入‘, ‘Eric‘, ‘Rain‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]
4 names.insert(5,"从eric后面插入试试新姿势")
5 names=[‘Alex‘, ‘Tenglan‘, ‘强行从Eric前面插入‘, ‘Eric‘, ‘Rain‘, ‘从eric后面插入试试新姿势‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]

修改

1 names=[‘Alex‘, ‘Tenglan‘, ‘强行从Eric前面插入‘, ‘Eric‘, ‘Rain‘, ‘从eric后面插入试试新姿势‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]
2 names[2] = "该换人了"
3 names=[‘Alex‘, ‘Tenglan‘, ‘该换人了‘, ‘Eric‘, ‘Rain‘, ‘从eric后面插入试试新姿势‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]

删除

1 del names[2]
2 names=[‘Alex‘, ‘Tenglan‘, ‘Eric‘, ‘Rain‘, ‘从eric后面插入试试新姿势‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]
3 del names[4]
4 names=[‘Alex‘, ‘Tenglan‘, ‘Eric‘, ‘Rain‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]
5 names.remove("Eric") #删除指定元素
6 names=[‘Alex‘, ‘Tenglan‘, ‘Rain‘, ‘Tom‘, ‘Amy‘, ‘我是新来的‘]
7 names.pop() #删除列表最后一个值 ‘我是新来的‘???或者随机删除一个
8 names=[‘Alex‘, ‘Tenglan‘, ‘Rain‘, ‘Tom‘, ‘Amy‘]

扩展

1 names=[‘Alex‘, ‘Tenglan‘, ‘Rain‘, ‘Tom‘, ‘Amy‘]
2 b = [1,2,3]
3 names.extend(b)
4 names=[‘Alex‘, ‘Tenglan‘, ‘Rain‘, ‘Tom‘, ‘Amy‘, 1, 2, 3]

拷贝

 1 import copy
 2 a = [1, 2, 3, 4, [‘a‘, ‘b‘]]  #原始对象
 3
 4 b = a  #赋值,传对象的引用
 5 c = copy.copy(a)  #对象拷贝,浅拷贝
 6 d = copy.deepcopy(a)  #对象拷贝,深拷贝
 7
 8 a.append(5)  #修改对象a
 9 a[4].append(‘c‘)  #修改对象a中的[‘a‘, ‘b‘]数组对象
10
11 print ‘a = ‘, a
12 print ‘b = ‘, b
13 print ‘c = ‘, c
14 print ‘d = ‘, d
15
16 输出结果:
17 a =  [1, 2, 3, 4, [‘a‘, ‘b‘, ‘c‘], 5]
18 b =  [1, 2, 3, 4, [‘a‘, ‘b‘, ‘c‘], 5]#引用:a怎么变化变化,b怎么变化,指向同一个对象
19 c =  [1, 2, 3, 4, [‘a‘, ‘b‘, ‘c‘]]#浅层拷贝:元素个数不能改变,但元素内容跟着b变化
20 d =  [1, 2, 3, 4, [‘a‘, ‘b‘]]#深层拷贝:元素个数和内容都不会随着a改变,已经指向另一个对象

统计

1 names=[‘Alex‘, ‘Tenglan‘, ‘Amy‘, ‘Tom‘, ‘Amy‘, 1, 2, 3]
2 names.count("Amy")
3  #2

排序&翻转

names=[‘Alex‘, ‘Tenglan‘, ‘Amy‘, ‘Tom‘, ‘Amy‘, 1, 2, 3]
names.sort() #排序
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: unorderable types: int() < str()   #3.0里不同数据类型不能放在一起排序了,擦
 names[-3] = ‘1‘
 names[-2] = ‘2‘
 names[-1] = ‘3‘
names=[‘Alex‘, ‘Amy‘, ‘Amy‘, ‘Tenglan‘, ‘Tom‘, ‘1‘, ‘2‘, ‘3‘] names.sort()
names=[‘1‘, ‘2‘, ‘3‘, ‘Alex‘, ‘Amy‘, ‘Amy‘, ‘Tenglan‘, ‘Tom‘]

names.reverse() #反转
names=[‘Tom‘, ‘Tenglan‘, ‘Amy‘, ‘Amy‘, ‘Alex‘, ‘3‘, ‘2‘, ‘1‘]

获取下标

1 names=[‘Tom‘, ‘Tenglan‘, ‘Amy‘, ‘Amy‘, ‘Alex‘, ‘3‘, ‘2‘, ‘1‘]
2 names.index("Amy")
3 #2 #只返回找到的第一个下标

元组

元组其实跟列表差不多,也是存一组数,只不是它一旦创建,便不能再修改,所以又叫只读列表

1 name = (‘A‘, ‘B‘, ‘C‘, ‘D‘)

它只有2个方法,一个是count,一个是index。

字符串

字符串特性:不可修改

 1 name.capitalize()  首字母大写
 2 name.casefold()   大写全部变小写
 3 name.center(50,"-")  输出 ‘---------------------Alex Li----------------------‘
 4 name.count(‘lex‘) 统计 lex出现次数
 5 name.encode()  将字符串编码成bytes格式
 6 name.endswith("Li")  判断字符串是否以 Li结尾
 7  "Alex\tLi".expandtabs(10) 输出‘Alex      Li‘, 将\t转换成多长的空格
 8  name.find(‘A‘)  查找A,找到返回其索引, 找不到返回-1
 9
10 format :
11     >>> msg = "my name is {}, and age is {}"
12     >>> msg.format("alex",22)
13     ‘my name is alex, and age is 22‘
14     >>> msg = "my name is {1}, and age is {0}"
15     >>> msg.format("alex",22)
16     ‘my name is 22, and age is alex‘
17     >>> msg = "my name is {name}, and age is {age}"
18     >>> msg.format(age=22,name="ale")
19     ‘my name is ale, and age is 22‘
20 format_map
21     >>> msg.format_map({‘name‘:‘alex‘,‘age‘:22})
22     ‘my name is alex, and age is 22‘
23
24
25 msg.index(‘a‘)  返回a所在字符串的索引
26 ‘9aA‘.isalnum()   True
27
28 ‘9‘.isdigit() 是否整数
29 name.isnumeric
30 name.isprintable
31 name.isspace
32 name.istitle
33 name.isupper
34  "|".join([‘alex‘,‘jack‘,‘rain‘])
35 ‘alex|jack|rain‘
36
37
38 maketrans
39     >>> intab = "aeiou"  #This is the string having actual characters.
40     >>> outtab = "12345" #This is the string having corresponding mapping character
41     >>> trantab = str.maketrans(intab, outtab)
42     >>>
43     >>> str = "this is string example....wow!!!"
44     >>> str.translate(trantab)
45     ‘th3s 3s str3ng 2x1mpl2....w4w!!!‘
46
47  msg.partition(‘is‘)   输出 (‘my name ‘, ‘is‘, ‘ {name}, and age is {age}‘)
48
49  >>> "alex li, chinese name is lijie".replace("li","LI",1)
50      ‘alex LI, chinese name is lijie‘
51
52  msg.swapcase 大小写互换
53
54
55  >>> msg.zfill(40)
56 ‘00000my name is {name}, and age is {age}‘
57
58
59
60 >>> n4.ljust(40,"-")
61 ‘Hello 2orld-----------------------------‘
62 >>> n4.rjust(40,"-")
63 ‘-----------------------------Hello 2orld‘
64
65
66 >>> b="ddefdsdff_哈哈"
67 >>> b.isidentifier() #检测一段字符串可否被当作标志符,即是否符合变量命名规则
68 True

字典

字典一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划、字母来查对应页的详细内容。

1 info = {
2     ‘stu1101‘: "TengLan Wu",
3     ‘stu1102‘: "LongZe Luola",
4     ‘stu1103‘: "XiaoZe Maliya",
5 }

字典的特性:

  • dict是无序的
  • key必须是唯一的,so 天生去重

增加

1 >>> info["stu1104"] = "苍井空"
2 >>> info
3 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1104‘: ‘苍井空‘, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1101‘: ‘TengLan Wu‘}

修改

1 >>> info[‘stu1101‘] = "武藤兰"
2 >>> info
3 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1101‘: ‘武藤兰‘}

删除

 1 >>> info
 2 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1101‘: ‘武藤兰‘}
 3 >>> info.pop("stu1101") #标准删除姿势
 4 ‘武藤兰‘
 5 >>> info
 6 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘}
 7 >>> del info[‘stu1103‘] #换个姿势删除
 8 >>> info
 9 {‘stu1102‘: ‘LongZe Luola‘}
10 >>>
11 >>>
12 >>>
13 >>> info = {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘}
14 >>> info
15 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘} #随机删除
16 >>> info.popitem()
17 (‘stu1102‘, ‘LongZe Luola‘)
18 >>> info
19 {‘stu1103‘: ‘XiaoZe Maliya‘}

查找

 1 info = {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘}
 2 >>> "stu1102" in info #标准用法
 3 True
 4 >>> info.get("stu1102")  #获取
 5 ‘LongZe Luola‘
 6 >>> info["stu1102"] #同上,但是看下面
 7 ‘LongZe Luola‘
 8 >>> info["stu1105"]  #如果一个key不存在,就报错,get不会,不存在只返回None
 9 Traceback (most recent call last):
10   File "<stdin>", line 1, in <module>
11 KeyError: ‘stu1105‘

多级字典嵌套

 1 av_catalog = {
 2     "欧美":{
 3         "www.youporn.com": ["很多免费的,世界最大的","质量一般"],
 4         "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
 5         "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
 6         "x-art.com":["质量很高,真的很高","全部收费,屌比请绕过"]
 7     },
 8     "日韩":{
 9         "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"]
10     },
11     "大陆":{
12         "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
13     }
14 }
15
16 av_catalog["大陆"]["1024"][1] += ",可以用爬虫爬下来"
17 print(av_catalog["大陆"]["1024"])
18 #ouput
19 [‘全部免费,真好,好人一生平安‘, ‘服务器在国外,慢,可以用爬虫爬下来‘]

其他操作

 1 #values
 2 >>> info.values()
 3 dict_values([‘LongZe Luola‘, ‘XiaoZe Maliya‘])
 4
 5 #keys
 6 >>> info.keys()
 7 dict_keys([‘stu1102‘, ‘stu1103‘])
 8
 9
10 #setdefault
11 >>> info.setdefault("stu1106","Alex")
12 ‘Alex‘
13 >>> info
14 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1106‘: ‘Alex‘}
15 >>> info.setdefault("stu1102","龙泽萝拉")
16 ‘LongZe Luola‘
17 >>> info
18 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1106‘: ‘Alex‘}
19
20
21 #update
22 >>> info
23 {‘stu1102‘: ‘LongZe Luola‘, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1106‘: ‘Alex‘}
24 >>> b = {1:2,3:4, "stu1102":"龙泽萝拉"}
25 >>> info.update(b)
26 >>> info
27 {‘stu1102‘: ‘龙泽萝拉‘, 1: 2, 3: 4, ‘stu1103‘: ‘XiaoZe Maliya‘, ‘stu1106‘: ‘Alex‘}
28
29 #items
30 info.items()
31 dict_items([(‘stu1102‘, ‘龙泽萝拉‘), (1, 2), (3, 4), (‘stu1103‘, ‘XiaoZe Maliya‘), (‘stu1106‘, ‘Alex‘)])
32
33
34 #通过一个列表生成默认dict,有个没办法解释的坑,少用吧这个
35 >>> dict.fromkeys([1,2,3],‘testd‘)
36 {1: ‘testd‘, 2: ‘testd‘, 3: ‘testd‘}

循环字典

#方法1
for key in info:
    print(key,info[key])

#方法2
for k,v in info.items(): #会先把dict转成list,数据里大时莫用
    print(k,v)

 练习参考python圣地购物车系统。

时间: 2024-10-11 16:46:40

python数据类型详解的相关文章

转 python数据类型详解

python数据类型详解 目录 1.字符串 2.布尔类型 3.整数 4.浮点数 5.数字 6.列表 7.元组 8.字典 9.日期 1.字符串 1.1.如何在Python中使用字符串 a.使用单引号(') 用单引号括起来表示字符串,例如: str='this is string'; print str; b.使用双引号(") 双引号中的字符串与单引号中的字符串用法完全相同,例如: str="this is string"; print str; c.使用三引号(''') 利用三

Python数据类型详解——列表

Python数据类型详解--列表 在"Python之基本数据类型概览"一节中,大概介绍了列表的基本用法,本节我们详细学一下列表. 如何定义列表:在[]内以英文里输入法的逗号,,按照索引,存放各种数据类型,每个位置代表一个元素. 回顾一下列表的特点: 1.可存放多个值. 2.按照从左到右的顺序定义列表元素,下标从0开始顺序访问,是有序的. 3.可修改指定索引位置对应的值,可变. 一.列表元素的增加操作 1.追加 用append方法将数据追加到列表的尾部 names = ['Kwan',

Python数据类型详解(列表,元组,字典,日期)

目录1.字符串2.布尔类型3.整数4.浮点数5.数字6.列表7.元组8.字典9.日期 1.字符串1.1.如何在Python中使用字符串a.使用单引号(')用单引号括起来表示字符串,例如:str='this is string';print str; b.使用双引号(")双引号中的字符串与单引号中的字符串用法完全相同,例如:str="this is string";print str; c.使用三引号(''')利用三引号,表示多行的字符串,可以在三引号中自由的使用单引号和双引号

python数据类型详解及列表字典集合推导式详解

一.运算符 Python语言支持以下类型的运算符: 算术运算符 如: #!/usr/bin/env python # -*- coding:utf-8 -*- a = 5 b = 6 print(a + b) 比较运算符 例: #!/usr/bin/env python # -*- coding:utf-8 -*- a = 5 b = 6 if a < b: print(True) else: print(False) 赋值运算符 例: #!/usr/bin/env python # -*- c

[转载] Python数据类型详解

原文链接:http://www.cnblogs.com/linjiqin/p/3608541.html 文章目录: 1.字符串 2.布尔类型 3.整数 4.浮点数 5.数字 6.列表 7.元组 8.字典 9.日期 1. 字符串 如何在python中使用字符串 a. 使用单引号(') 用单引号括起来表示字符串,例如: str='this is string'; print str; b. 使用双引号(") 双引号中的字符串与单引号中的字符串用法完全相同,例如: str="this is

python数据类型详解(全面)

1.字符串1.1.如何在Python中使用字符串a.使用单引号(')用单引号括起来表示字符串,例如: str='this is string'; print str; b.使用双引号(")双引号中的字符串与单引号中的字符串用法完全相同,例如: str="this is string"; print str; c.使用三引号(''')利用三引号,表示多行的字符串,可以在三引号中自由的使用单引号和双引号,例如: ''' 遇到问题没人解答?小编创建了一个Python学习交流QQ群:

python正则表达式详解

python正则表达式详解 正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技能,正则表达式的在不同的语言中使用方式可能不一样,不过只要学会了任意一门语言的正则表达式用法,其他语言中大部分也只是换了个函数的名称而已,本质都是一样的.下面,我来介绍一下python中的正则表达式是怎么使用的. 首先,python中的正则表达式大致分为以下几部分: 元字符 模式 函数 re 内置对象用法 分组用

PHP100-第三讲 PHP5.4 语法、常量、变量、数据类型详解

内容摘要: ①PHP5.4 的基本语法与写作格式 ②PHP5.4 的变量与变量数据类型 ③PHP5.4 的系统常量与自定义常量 PHP5.4 的基本语法与写作格式: 任何程序语言都有自己的语言风格,PHP语言也有自己独特的风格,虽然也继承了许多Perl和C的语言特色.但经过多年的发展PHP已经成为了一个成熟 的编程语言,所以我们还需要认真的学习PHP的独特语法.PHP一个很大的特色就是与HTML标签语言进行混编,这种模式是今后很长一段学习过程中所用到 的格式,因此我们先来通过一个例子来认识一下P

MySQL 数据类型 详解

MySQL 数据类型 详解 MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数.许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者用零填补. 1.整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节 范围(-128~127) smallint(m) 2个字节 范围(-32768~32767) mediumint(m) 3个字节 范围(-8388608~83