Python基本数据类型——元组与字符串

目录

1 概述

1.1 元组

 1.2 字符串

2 元组 

2.1 空元组

2.2 一个值的元组 

2.3 元组操作

3 字符串

3.1 字符串简介

3.2 find 

3.3 split  

3.4 join

3.5 strip

3.6 replace 

3.7 translate 

3.8 lower/upper 


1 概述

在前面我们已经分享了Python思维导图,这一节,我们讲解Python基本数据类型:元组与字符串。

1.1 元组

 1.2 字符串

 

2 元组 

Python 中,元组是一种不可变序列,它使用圆括号来表示:
1. >>> a = ( 1 , 2 , 3 ) # a 是一个元组
2. >>> a
3. ( 1 , 2 , 3 )
4. >>> a [ 0 ] = 6 # 元组是不可变的,不能对它进行赋值操作
5. Traceback ( most recent call last ):
6. File "<stdin>" , line 1 , in < module >
7. TypeError : 'tuple' object does not support item assignment

2.1 空元组

创建一个空元组可以用没有包含内容的圆括号来表示: 

1. >>> a = ()
2. >>> a
3. ()

2.2 一个值的元组 

创建一个值的元组需要在值后面再加一个逗号, 这个比较特殊,需要牢牢记住
1. >>> a = ( 12 ,) # 在值后面再加一个逗号
2. >>> a
3. ( 12 ,)
4. >>> type ( a )
5. < type 'tuple' >
6. >>>
7. >>> b = ( 12 ) # 只是使用括号括起来,而没有加逗号,不是元组,本质上是 b = 12
8. >>> b
9. 12
10. >>> type ( b )
11. < type 'int' >

2.3 元组操作

元组也是一种序列,因此也可以对它进行索引、分片等。由于它是不可变的,因此就没有类似列表的append, extend, sort 等方法。

3 字符串

3.1 字符串简介

字符串也是一种序列,因此,通用的序列操作,比如索引,分片,加法,乘法等对它同样适用。比如: 

1. >>> s = 'hello, '
2. >>> s [ 0 ] # 索引
3. 'h'
4. >>> s [ 1 : 3 ] # 分片
5. 'el'
6. >>> s + 'world' # 加法
7. 'hello, world'
8. >>> s * 2 # 乘法
9. 'hello, hello, '
但需要注意的是,字符串和元组一样,也是不可变的,所以你不能对它进行赋值等操作:
1. >>> s = 'hello'
2. >>> s [ 1 ] = 'ab' # 不能对它进行赋值
3. Traceback ( most recent call last ):
4. File "<stdin>" , line 1 , in < module >
5. TypeError : 'str' object does not support item assignment

 除了通用的序列操作,字符串还有自己的方法,比如 join, lower, upper 等。字符串的方法特别多,这里只介绍一些常用的方法,如下:

 

3.2 find 

find 方法用于在一个字符串中查找子串,它返回子串所在位置的最左端索引,如果没有找到,则返回-1。看看例子:
1. >>> motto = "to be or not to be, that is a question"
2. >>> motto . find ( 'be' ) # 返回 'b' 所在的位置,即 3
3. 3
4. >>> motto . find ( 'be' , 4 ) # 指定从起始位置开始找,找到的是第 2 'be'
5. 16
6. >>> motto . find ( 'be' , 4 , 7 ) # 指定起始位置和终点位置,没有找到,返回 -1
7. - 1

3.3 split  

split 方法用于将字符串分割成序列。看看例子:
1. >>> '/user/bin/ssh' . split ( '/' ) # 使用 '/' 作为分隔符
2. [ '' , 'user' , 'bin' , 'ssh' ]
3. >>> '1+2+3+4+5' . split ( '+' ) # 使用 '+' 作为分隔符
4. [ '1' , '2' , '3' , '4' , '5' ]
5. >>> 'that is a question' . split () # 没有提供分割符,默认使用所有空格作为分隔符
6. [ 'that' , 'is' , 'a' , 'question' ]
需要注意的是,如果不提供分隔符,则默认会使用所有空格作为分隔符(空格、制表符、换行等)。

3.4 join

join 方法可以说是 split 的逆方法,它用于将序列中的元素连接起来。看看例子:
1. >>> '/' . join ([ '' , 'user' , 'bin' , 'ssh' ])
2. '/user/bin/ssh'
3. >>>
4. >>> '+' . join ([ '1' , '2' , '3' , '4' , '5' ])
5. '1+2+3+4+5'
6. >>> ' ' . join ([ 'that' , 'is' , 'a' , 'question' ])
7. 'that is a question'
8. >>> '' . join ([ 'h' , 'e' , 'll' , 'o' ])
9. 'hello'
10. >>> '+' . join ([ 1 , 2 , 3 , 4 , 5 ]) # 不能是数字
11. Traceback ( most recent call last ):
12. File "<stdin>" , line 1 , in < module >
13. TypeError : sequence item 0 : expected string , int found

3.5 strip

strip 方法用于移除字符串左右两侧的空格,但不包括内部,当然也可以指定需要移除的字符串。看看例子:
1. >>> ' hello world! ' . strip () # 移除左右两侧空格
2. 'hello world!'
3. >>> '%%% hello world!!! ####' . strip ( '%#' ) # 移除左右两侧的 '%' '#'
4. ' hello world!!! '
5. >>> '%%% hello world!!! ####' . strip ( '%# ' ) # 移除左右两侧的 '%' '#' 或空格
6. 'hello world!!!'

3.6 replace 

replace 方法用于替换字符串中的所有匹配项。看看例子:
1. >>> motto = 'To be or not To be, that is a question'
2. >>> motto . replace ( 'To' , 'to' ) # 'to' 替换所有的 'To' ,返回了一个新的字符串
3. 'to be or not to be, that is a question'
4. >>> motto # 原字符串保持不变
5. 'To be or not To be, that is a question'

3.7 translate 

translate 方法和 replace 方法类似,也可以用于替换字符串中的某些部分,但 translate
法只处理单个字符。
translate 方法的使用形式如下:
str.translate(table[, deletechars])
其中, table 是一个包含 256 个字符的转换表,可通过 maketrans 方法转换而来,
deletechars 是字符串中要过滤的字符集。
看看例子:
1. >>> from string import maketrans
2. >>> table = maketrans ( 'aeiou' , '12345' )
3. >>> motto = 'to be or not to be, that is a question'
4. >>> motto . translate ( table )
5. 't4 b2 4r n4t t4 b2, th1t 3s 1 q52st34n'
6. >>> motto
7. 'to be or not to be, that is a question'
8. >>> motto . translate ( table , 'rqu' ) # 移除所有的 'r', 'q', 'u'
9. 't4 b2 4 n4t t4 b2, th1t 3s 1 2st34n'
可以看到, maketrans 接收两个参数:两个等长的字符串,表示第一个字符串的每个字符用第二个字符串对应位置的字符替代,在上面的例子中,就是 ‘a’ ‘1’ 替代, ’e’ ‘2’ 替代,等等,注意,是单个字符的代替,而不是整个字符串的替代。因此,motto 中的 o 都被替换为 4 e 都被替换为 2 ,等等。

3.8 lower/upper 

lower/upper 用于返回字符串的大写或小写形式。看看例子
1. >>> x = 'PYTHON'
2. >>> x . lower ()
3. 'python'
4. >>> x
5. 'PYTHON'
6. >>>
7. >>> y = 'python'
8. >>> y . upper ()
9. 'PYTHON'
10. >>> y
11. 'python'
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

荔枝科研社

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值