【Python学习之四】集合类型

环境
  虚拟机:VMware 10
  Linux版本:CentOS-6.5-x86_64
  客户端:Xshell4
  FTP:Xftp4
  python3.6

一、字符串:字符串实际上就是字符的数组
1、切片是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。
(1)python中从左侧开始,下标 0 开始;从右侧,下标从-1开始;
(2)切片的语法:[起始:结束:步长],选取的区间属于左闭右开型,即从"起始"位开始,到"结束"位的前一位结束(不包含结束位本身),步长:表示下标变化的规律。

示例:

a=‘abcdefg‘
print(a[0])#取字符串0位置字符:a
print(a[-1])#从右侧取字符串-1位置字符:g

print(a[2:10])#如果结束位置超过字符串总长度 不会报错  会一直取到字符串末尾:cdefg
#print(a[10])#如果直接使用下标超过字符串长度的下标取值 会报错:IndexError: string index out of range

print(a[:3])#取字符串0-2位置字符 起始位置0可以省略:abc
print(a[3:])#取字符串3到末尾字符 结束位置为末尾 可以省略:defg

print(a[0:3])#取字符串0-2位置字符:abc
print(a[1:-1])#取 下标为1开始 到 最后第2个  之间的字符
print(a[0:4:3])#从0位置开始 每3个长度取一个字符串:ad
print(a[::-1])#末尾到开始区间 按照从右向左取值 相当于反转字符串:gfedcba
print(a[0:6:-2])#没有结果 从0开始向左没有值了
print(a[6:0:-2])#从下标6开始向左每隔2个位置取值 不包括0位置:gec

2、字符串常用API
<1>find == java Indexof方法
检测 str 是否包含在 mystr中,如果是返回开始的索引值,否则返回-1
mystr.find(str, start=0, end=len(mystr))
<2>index
跟find()方法一样,只不过如果str不在 mystr中会报一个异常.
mystr.index(str, start=0, end=len(mystr))
<3>count
返回 str在start和end之间 在 mystr里面出现的次数
mystr.count(str, start=0, end=len(mystr))
<4>replace
把 mystr 中的 str1 替换成 str2,如果 count 指定,则替换不超过 count 次.
mystr.replace(str1, str2, mystr.count(str1))
<5>split
以 str 为分隔符切片 mystr,如果 maxsplit有指定值,则仅分隔 maxsplit 个子字符串
mystr.split(str=" ", 2)
<6>capitalize
把字符串的第一个字符大写
mystr.capitalize()
<7>title
把字符串的每个单词首字母大写
<8>startswith
检查字符串是否是以 obj 开头, 是则返回 True,否则返回 False
mystr.startswith(obj)
<9>endswith
检查字符串是否以obj结束,如果是返回True,否则返回 False.
mystr.endswith(obj)
<10>lower
转换 mystr 中所有大写字符为小写
mystr.lower()
<11>upper
转换 mystr 中的小写字母为大写
mystr.upper()
<12>ljust
返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串
mystr.ljust(width)
<13>rjust
返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串
mystr.rjust(width)
<14>center
返回一个原字符串居中,并使用空格填充至长度 width 的新字符串
mystr.center(width)
<15>lstrip
删除 mystr 左边的空白字符
mystr.lstrip()
<16>rstrip
删除 mystr 字符串末尾的空白字符
mystr.rstrip()
<17>strip ---java trim
删除mystr字符串两端的空白字符
<18>rfind
类似于 find()函数,不过是从右边开始查找.
mystr.rfind(str, start=0,end=len(mystr) )
<19>rindex
类似于 index(),不过是从右边开始.
mystr.rindex( str, start=0,end=len(mystr))
<20>partition
把mystr以str分割成三部分,str前,str和str后
mystr.partition(str)
<21>rpartition
类似于 partition()函数,不过是从右边开始.
mystr.rpartition(str)
<22>splitlines
按照换行符分隔,返回一个包含各行作为元素的列表
mystr.splitlines()
<23>isalpha
如果 mystr 所有字符都是字母 则返回 True,否则返回 False
mystr.isalpha()
<24>isdigit
如果 mystr 只包含数字则返回 True 否则返回 False.
mystr.isdigit()
<25>isalnum
如果 mystr 所有字符都是字母或数字则返回 True,否则返回 False
mystr.isalnum()
<26>isspace
如果 mystr 中只包含空格,则返回 True,否则返回 False.
mystr.isspace()
<27>join

将mystr 插入list的每个元素后面(list最后一个元素除外),构造出一个新的字符串

mystr.join(list)

示例:

b=‘ab cdefg‘
print(b.find(‘b‘))#1
print(b.find(‘d‘,0))#4

#print(b.index(‘t‘))#ValueError: substring not found

print(b.count(‘d‘))#1
print(b.replace(‘f‘, ‘123‘))#ab cde123g

print(b.split(sep=‘ ‘, maxsplit=1)) #[‘ab‘, ‘cdefg‘]
print(b.capitalize())#Ab cdefg
print(b.title())#Ab Cdefg
print(b.startswith("ab"))#True
print(b.endswith(‘cc‘))#False
print(b.lower())#ab cdefg
print(b.upper())#AB CDEFG
print(b.ljust(20))#ab cdefg
print(b.rjust(20))#            ab cdefg
print(‘*‘*50)#**************************************************
print(b.center(50))#                     ab cdefg
print(‘*‘*50)#**************************************************
print(b.strip())
print(b.partition(‘ ‘))#(‘ab‘, ‘ ‘, ‘cdefg‘)
c=[‘1‘,‘2‘,‘3‘]
print(b.join(c))#1ab cdefg2ab cdefg3

2、

列表 list
Python内置的一种数据类型。list是一种有序、可重复、元素数据类型多样化的集合,可以随时添加和删除元素,使用中括号[]。

a=[‘a‘,‘b‘,‘c‘,10,12.5]
b=[‘1‘,‘2‘]
print(len(a))#len()是内置函数 用来计算集合元素个数:5
print(a[2])#列表也是通过下标来获取元素:c
#print(a[6])#超出长度取值报错:IndexError: list index out of range

1、列表增加元素
(1)append:在列表末尾追加新元素

a.append(‘d‘)
print(a)#[‘a‘, ‘b‘, ‘c‘, 10, 12.5, ‘d‘]
a.append(b)
print(a)#[‘a‘, ‘b‘, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘]]

(2)extend:可以将另一个集合中的元素逐一添加到列表中

a.extend(b)
print(a)#[‘a‘, ‘b‘, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘], ‘1‘, ‘2‘]

(3)insert: 在指定位置index前插入元素object

a.insert(2, 500)
print(a)#[‘a‘, ‘b‘, 500, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘], ‘1‘, ‘2‘]

2、修改元素
修改元素的时候,要通过下标来确定要修改的是哪个元素,然后才能进行修改

a[0]=‘l‘
print(a)#[‘l‘, ‘b‘, 500, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘], ‘1‘, ‘2‘]

3、查找元素
in(存在),如果存在那么结果为true,否则为false
not in(不存在),如果不存在那么结果为true,否则false

print(10 in a)#True

index:返回某个元素下标,找不到报错ValueError: ‘ ‘ is not in list
count:返回某个元素的个数,找不到报错ValueError: ‘ ‘ is not in list

print(a.index(‘a‘, ))#找不到报错ValueError: ‘a‘ is not in list
print(a.count(‘a‘))#找不到报错ValueError: ‘a‘ is not in list

4、删除元素
pop:默认删除最后一个元素

a.pop()
print(a)#[‘l‘, ‘b‘, 500, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘], ‘1‘]

remove:根据元素的值进行删除第一个

a.remove(‘b‘)
print(a)#[‘l‘, 500, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘], ‘1‘]

del:根据下标进行删除,其实可以删除所有变量

del(a[0])
print(a)#[500, ‘c‘, 10, 12.5, ‘d‘, [‘1‘, ‘2‘], ‘1‘]
del(a)
print(a)#NameError: name ‘a‘ is not defined

5、排序

sort方法是将list按特定顺序重新排列,默认为由小到大,参数reverse=True可改为倒序,由大到小。
reverse方法是将list逆置。

c = [1, 4, 2, 3]
c.sort()
print(c)#[1, 2, 3, 4]
c.reverse()
print(c)#[4, 3, 2, 1]

6、枚举

打印下标和元素

chars = [‘a‘, ‘b‘, ‘c‘, ‘d‘]
for i,chr in enumerate(chars):
    print(i,chr)
# 0 a
# 1 b
# 2 c
# 3 d

三、元组
Python的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号(),列表使用方括号[]

元祖也可以使用下标获取元素:

t=(‘a‘,‘b‘,‘c‘,10,12.5,[‘A‘,‘B‘])
print(t)#(‘a‘, ‘b‘, ‘c‘, 10, 12.5, [‘A‘, ‘B‘])
print(t[2])#c

tt=(1,)#只有1个元素的tuple定义时必须加一个逗号,,来消除歧义
print(tt)#(1,)
ttt=(1)
print(ttt)#1

元组用的不多,主要注意是元素不可改变,如果元素是引用类型,则引用类型元素中元素是可以改变的

t[5][0]=‘X‘
t[5][1]=‘Y‘
print(t)#(‘a‘, ‘b‘, ‘c‘, 10, 12.5, [‘X‘, ‘Y‘])

t[5]=[‘X‘,‘Y‘]#报错TypeError: ‘tuple‘ object does not support item assignment

四、字典

参考:

Python学习笔记

原文地址:https://www.cnblogs.com/cac2020/p/10805642.html

时间: 2024-10-06 03:02:56

【Python学习之四】集合类型的相关文章

【Python 学习笔记 2】Python中常用集合类型:List,Tuple,Set,Dict使用简介

在使用Python编程中,我们最常用的几种集合类型是:List,Tuple,Set,Dict:下面简单聊聊这几种集合类型: List 列表:相当于一个数组,不过list的长度是自动变化的而且列表元素自由的,不必每个元素都是同一种类型.它的简洁的定义方式是a=[].是一种有序组合,可以删除和添加其中的元素: List的基本操作如下: ##生成一个list,并赋值给list_ex >>> list_ex=[1,3,4,"list","Tuple",&q

【python基础】集合类型

集合类型: 作用: --> 关系运算(交集,并集,差集) --> 去重(有局限性) 定义方法:set() linuxers = {1,1.1,'a',(1,2,3)} ##集合内的值,只能为不可变类型,比如int,str,float,tupleprint(type(linuxers))<class 'set'> 需要掌握: 1.集合的定义方法 定义方法类似于字典,{}内,以逗号分割,但不同于字典之处不是key:varual格式,集合内的元素一定是不可变类型 1 pythoners

Swift学习笔记 - 教程学习三 集合类型 (Collection Types)

集合类型 (Collection Types) 本节及前面用到的for…in句型在后面的循环控制部分,if let 见基础篇.如果某些字符看不到,请到博客园来看原文.——新波 Swift提供了三种基本集合类型,数组(array).集合(set)和字典(dictionary).数组是一组按序排列的数据,集合是一组各不相同的无序数据,字典是一组与关键值相关联的无序数据.参见下图. 3.1 集合的可变性Mutability of Collections 与前面的字符串一样,赋值给变量的集合是可变的,赋

Swift 学习- 05 -- 集合类型

// 集合类型 // swift 提供 Arrays , Sets 和 Dictionaries 三种基本的集合类型用来存储数据 , 数组(Arrays) 是有序数据的集, 集合(Sets)是无序无重复数据的集, 字典(Dictionaries) 是无序的键值对的集 // swift 语言中的 Arrays, Sets 和 Dictionaries 中存储的数据值类型必须明确, 这意味着我们不能把不正确的数据类型插入其中, 同事这也说明我们完全可以取回值的类型非常自信 // 集合的可变性 //

[Google Guava]学习--新集合类型Multimap

每个有经验的Java程序员都在某处实现过Map<K, List<V>>或Map<K, Set<V>>,并且要忍受这个结构的笨拙. 假如目前有个需求是给两个年级添加5个学生,并且统计出一年级学生的信息: public class MultimapTest { class Student { String name; int age; } private static final String CLASS_NAME_1 = "一年级"; pr

Python学习日记---集合

一.集合的构造方法:   集合名 = set() 1. set()中可以有有一个参数,参数类型必须是可迭代的,例如字符串.列表,就是能拆分成单独元素的意思 2.如果不带参数则表示构造一个空集 >>> aSet = set("abcd")    #参数为字符串 >>> aSet {'c', 'b', 'd', 'a'} >>> bSet = ['a',1.5,'set']  #参数为普通列表 >>> bSet ['a

,NET菜鸟基础学习之——集合类型

刚刚接触.net一个月,细细的学,整理了一些别人空间上看到的资料,方便自己学习,如果大家有兴趣可以看一下. 集合,表示可以通过遍历每个元素来访问的一组对象(特别是可使用foreach循环访问)一个集合包括多个元素,即有一个集合类对象和N个元素对因为任何集合类都实现了IEnumerable接口,所以任何集合类对象都有一个GetEnumerator()方法,该方法可以返回一个实现了 IEnumerator接口的对象,这个返回的IEnumerator对象既不是集合类对象,也不是集合的元素类对象,它是一

Python学习:集合(set)

python的set和其他语言类似, 是一个无序不重复元素集, 基本功能包括关系测试和消除重复元素. 集合对象还支持union(联合), intersection(交), difference(差)和sysmmetric difference(对称差集)等数学运算. sets 支持 x in set, len(set),和 for x in set.作为一个无序的集合,sets不记录元素位置或者插入点.因此,sets不支持 indexing, slicing, 或其它类序列(sequence-l

Python学习1--数据类型与循环要点

python笔记: 1.E记法,科学计数法等于10的多少次方.1.5e5=150000.0.注:得到的数字为浮点数.; 2.类型转换:int(转化为整形),str(转换为字符串),float(): 注:浮点数转化为整数,截取整数部分.int(3.6)=3; 整形转化为浮点型,加.0;float(3)=3.0; float(4e10)='4e+10';+表示正负: 当BIF关键字被用于普通变量名后,则在以后的使用中,python会继续使用该关键字新的身份,不会使用原来BIF的功能.例:str='z