python学习笔记-04

高级数据类型

一组按照顺序排列的值称为序列,python中存在三种内置的序列类型:字符串、列表和元组。序列可以支持索引和切片的操作,第一个索引值为0表示从左向右找,第一个索引值为负数表示从右找。

1.字符串操作

1.1 切片
切片是指选取字符串中的某些数据,语法:字符串[开始下标:结束下标:步长],切片截取的内容不包括结束下标对应的数据,步长是指隔几个下标获取一个字符,步长默认是1。

 test='hello world'
print('完整字符串%s'%test)
print('%s是第三个到第五个之间的数据'%test[2:5])  #包括下标为2的不包括下标为5的,步长默认为1
print('第三个开始到最后%s'%test[3:])
print('第一个开始到第三个%s'%test[:3])
print('倒叙输出%s'%test[::-1])  #负号表示方向,1是步长,从右向左输出

在这里插入图片描述

1.2 常用函数
在这里插入图片描述

test=' python '
print(type(test))    #打印test的类型
k=1
for i in test:
    print('第%d个字符是%s'%(k,i))
    k+=1
    pass
print('原本的值%s'%test)
print('首字母大写函数测试%s'%test.capitalize())
print('本身没变%s'%test)
print('stripe函数去除空格后%s这样的'%test.strip())
print('只删除左边的空格%s后'%test.lstrip())
print('只删除右边的空格%s后'%test.rstrip())
print('%s的内存地址%d'%(test,id(test)))
print('是否以p开头%s'%test.startswith('p')) #返回布尔值
print('是否以空格开头%s'%test.startswith(' '))
print('是否以p结尾%s'%test.endswith('p'))
print('是否以空格结尾%s'%test.endswith(' '))
print('大写转换%s'%test.upper())
test1='PYTHON'
print('小写转换%s'%test1.lower())
t=test   #字符串复制,把test的内存地址给了t
print('%s的内存地址是%d'%(t,id(t)))  #之所以叫复制不叫赋值是因为地址都是一样的
print(test.find('P'))  #find函数查找目标在序列中的位置,没有返回-1,有返回下标,如果查找到两个返回第一个
print(test.find('p'))
print(test.index('p'))   #index函数也是查找目标在字符串中的索引值,找到返回下标
print(test.index('P'))   #没找到会报错

在这里插入图片描述

在这里插入图片描述

2.列表操作

列表是一种有序的集合,可以增删改查其中的元素,数据项可以是任何类型的数据,支持索引和切片操作。

在这里插入图片描述

增加函数:append、extend、insert
修改:只要通过索引直接重新赋值就可以
删除函数:pop、remove、del
#定义一个空列表
li=[]
print(type(li))
#len函数可以获取列表中的数据个数或字符串的长度
li1=[1,2.4,"你好",True]
print(len(li1))   #返回列表li1的长度
str='snshj'
print(len(str))
print(li1)  #输出列表
print(li1[0])  #输出第一个元素
print(li1[1:3]) #输出第二个元素到第三个元素
print(li1[::-1]) #倒叙输出
print(li1*3)  #复制延长三次
#列表的增加
li1.append(['fff','ddd'])
li1.append(99)    #什么都能加,也可以加一个列表
print(li1)
li1.insert(1,'在索引值为1的地方插入数据')
#批量增加数据
rs=list(range(10))   #生成十个数并转为列表类型
li1.extend(rs)    #扩展、批量添加
print(li1)
#或者也可以直接扩展一个列表
li1.extend([1,12,34])
print(li1)    #可以从这里看到重复了也会加入进去
#修改
li1[0]='change'
print(li1)
#删除
del li1[0]   #删除列表中第一个元素
print(li1)
#批量删除
del li1[1:7:2] #按步长和范围批量删除
print(li1)
li1.remove(12)  #删除指定元素
print(li1)
li1.pop(2)  #删除指定下标的项
print(li1)
#查找
print(li1.index(1))  #返回元素1的下标,可以看出他返回的是第一个符合的位置
print(li1.index(1,5,19)) #表示返回从索引为5的数据开始查1这个元素,查到索引为19的元素,如果没找到就报错,找到就返回下标
#反转列表
li1.reverse()
print(li1)
print(li1.reverse())

在这里插入图片描述

len函数可以输出列表的数据项个数和求得字符串的长度

3.元组操作

元组是一种不可变的序列,创建后不能做任何修改,不能进行增删改,元组中的数据项用逗号分割,可以是任何数据类型,支持切片操作,和列表操作很像,都可以通过下标访问。但是元组中的元素不可以修改,而列表中的元素可以修改;元组使用小括号,列表使用中括号。当元组中只有一个元素时,要加逗号,不然会当作整型处理。
元组只能进行查询,但是可以对元组中的列表修改。

#元组的创建
tua=()   #创建一个空元组
print(type(tua))
print(id(tua))
tua=(1)
print(type(tua))   #如果只有一个数值不加逗号就会解释成int型
print(id(tua))    #重新赋值之后内存地址也变了
tua=(1,)
print(type(tua))   #加上逗号就好了
tua=('ji')
print(type(tua))   #只有一项解释成了字符型
tua=(1,2.3,'heihei',[1,2,'list'])  #创建一个正经元组
print(tua)
#元组的查询
for item in tua:
    print(item,end=" ")
    pass
print('用下标取%s'%tua[2])
print('用切片:')
print(tua[2:4])
print(tua[::-1])  #倒叙输出
print(tua)
print('下标-1的值也就是最后一个:',end=' ')
print(tua[-1])
print('下标-2的值是%s也就是倒数第二个'%tua[-2])
print('下标-3的值是%d也就是倒数第三个'%tua[-3])
print('下标-4的值是%d也就是倒数第四个'%tua[-4])
print(tua[-2:-1:])
#可以对元组中的列表进行修改
tua[3][0]=5678
print(tua)
tub=tuple(range(10))
print(tub)
#统计元组中到底有几个某元素
tub=(1,3,345,1,5,1)
print(tub.count(1))
print(tub.count(3))

在这里插入图片描述

4.字典操作

字典可以存储任意对象,是无序集合不是序列,以键值对的方式呈现,{‘key’,‘value’}。当在字典中查找元素时通过键查找。与列表一样,字典可以增删改查。
字典的键只能是不可变类型,比如数字、元组、字符串。

字典的键key不能重复,值value可以重复
如果存在重复的键,后者会覆盖前者

在这里插入图片描述

#创建一个空字典
dictA={}
print(type(dictA))
#增
dictA['name']='clis'   #name表示key,clis表示value
dictA['na']='clo'
print(dictA)
#改
dictA['name']='cli'
print(dictA)
print('dictA字典长度为%d'%len(dictA))
print('通过键查找键为name的值%s'%dictA['name'])
dictA.update({'name':'dsfd'})   #用update函数修改,也可以用于增加键值对
print(dictA)
dictA.update({'insert':'haha'})
print(dictA)
#遍历字典
print(dictA.keys())  #获取所有键
print(dictA.values())  #获取所有值
print(dictA.items())  #获取所有的数据项、键值对
for item in dictA.items():
    print(item)
    pass
for key,value in dictA.items():
    print('%s==%s'%(key,value))
    pass
#删除操作
del dictA['name']
print(dictA)
dictA.pop('insert')
print(dictA)
#声明一个有值的字典
dictB={'key2':'value1','key1':'value2'}
print(type(dictB))
print(dictB)
#对字典进行排序,按照ASCII码进行排序
print(sorted(dictB.items(),key=lambda d:d[0]))   #0指按照键排序
print(sorted(dictB.items(),key=lambda d:d[1]))   #1指按照值排序
#这里要注意,排序只能排相同类型的,如果是不同类型的,排不了,会报错

在这里插入图片描述

update函数,当更新的键值不存在时,就可以当做增加使用;存在时就更新。

5.共同的方法

在这里插入图片描述

#字符串
strA='diyige'
strB='dierge'
print(strA+strB)   #合并
print(strA*3)      #复制
print('yi' in strA)    #看对象是否存在,返回布尔类型的值
print('er' in strA)

#列表
listA=list(range(10))
listB=list(range(11,20))
print(listA+listB)      #合并
print(listA*3)          #复制
print(12 in listA)      #看对象是否存在
print(2 in listA)

#元组
tua=(1,3,45,5)
tub=('asd',234)
print(tua+tub)    #合并
print(tub*3)      #复制
print(3 in tub)   #看是否存在
print(3 in tua)  

#字典
dictA={'name':'paul','age':18}
print('aa' in dictA)    #看某值是否为字典的键值
print('name' in dictA)
print('paul' in dictA)

在这里插入图片描述

Python学习笔记》是由皮大庆编写的一本关于Python语言学习的教材。在这本书中,作者详细介绍了Python语言的基础知识、语法规则以及常用的编程技巧。 首先,作者简要介绍了Python语言的特点和优势。他提到,Python是一种易于学习和使用的编程语言,受到了广大程序员的喜爱。Python具有简洁、清晰的语法结构,使得代码可读性极高,同时也提供了丰富的库和模块,能够快速实现各种功能。 接着,作者详细讲解了Python的基本语法。他从变量、数据类型、运算符等基础知识开始,逐步介绍了条件语句、循环控制、函数、模块等高级概念。同时,作者通过大量的示例代码和实践案例,帮助读者加深对Python编程的理解和应用。 在书中,作者还特别强调了编写规范和良好的编程习惯。他从命名规范、注释风格、代码缩进等方面指导读者如何写出清晰、可读性强的Python代码。作者认为,良好的编程习惯对于提高代码质量和提高工作效率非常重要。 此外,作者还介绍了Python的常用库和模块。他提到了一些常用的库,如Numpy、Pandas、Matplotlib等。这些库在数据处理、科学计算、可视化等领域有广泛的应用,帮助读者更好地解决实际问题。 总的来说,《Python学习笔记》是一本非常实用和全面的Python学习教材。通过学习这本书,读者可以系统地学习和掌握Python编程的基础知识和高级应用技巧,为以后的编程学习和工作打下坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值