如何用Python字符串进行切片操作?
Posted 小熊猫爱恰饭
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何用Python字符串进行切片操作?相关的知识,希望对你有一定的参考价值。
嗨害大家好鸭!我是小熊猫~
我们基本上都知道Python的序列对象
都是可以用索引号来引用的元素的,
索引号可以是正数由0开始从左向右,
也可以是负数由-1开始从右向左。
在Python中对于具有序列结构的数据来说都可以使用切片操作,
需注意的是序列对象某个索引位置返回的是一个元素,
而切片操作返回是和被切片对象相同类型对象的副本。
今天练习Python主要与大家一起谈谈Python字符串切片操作的那些事。
一、字符串的切片
字符串 'xxx’和 Unicode字符串 u’xxx’也可以看成是一种list,
每个元素就是一个字符。
因此,字符串也可以用切片操作,
只是操作结果仍是字符串。
在很多编程语言中,
针对字符串提供了很多各种截取函数,
其实目的就是对字符串切片。
Python没有针对字符串的截取函数,
只需要切片一个操作就可以完成,非常简单。
切片操作(slice)可以从一个字符串中获取子字符串(字符串的一部分)。
我们使用一对方括号、起始偏移量start、终止偏移量end 以及可选的步长step 来定义一个分片。
格式: [start🔚step]
[:] 提取从开头(默认位置0)到结尾(默认位置-1)的整个字符串
[start:] 从start 提取到结尾
[:end] 从开头提取到end - 1
[start:end] 从start 提取到end - 1
[start🔚step] 从start 提取到end - 1,每step 个字符提取一个
左侧第一个字符的位置/偏移量为0,右侧最后一个字符的位置/偏移量为-1
二、实战
任务:
请设计一个函数,它接受一个字符串,
然后返回一个仅首字母变成大写的字符串。
提示:利用切片操作简化字符串操作。
字符串有个方法 upper() 可以把字符变成大写字母,
但它会把所有字母都变成大写。
print("abc".upper())
#输出
ABC
而我们只想让字符串的首字母变大写,
因此可以通过使用字符串的切片操作来实现,
代码如下:
'''
def firstCharUpper(s):
return s[0].upper() + s[1:]
print(firstCharUpper('hello'))
#输出
Hello
习题:实现strStr() By Python
给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。
示例 1:
输入:haystack = “hello”, needle = "ll"输出:2
示例 2:
输入:haystack = “aaaaa”, needle = "bba"输出:-1
关键思维:
需要从haystack 字符串截取一个完整的 needle 字符串,
自然而然想到字符串的切片方法
class Solution(object):
def strStr(self, haystack,needle):
"""
:type haystack: str
:type needle: str
:rtype: int
"""
if not needle:
return 0
h_h = len(haystack)
h_n = len(needle)
if h_h < h_n:
return -1
for i in range(h_h - h_n + 1):
if haystack[i:i+h_n] == needle:
return i
return -1
除了字符串的切片操作,还有哪些方法,欢迎大家留言讨论
我是小熊猫,咱下篇文章再见啦(✿◡‿◡)
Python中的切片操作
python中的切片操作功能十分强大,通常我们利用切片来进行提取信息,进行相关的操作,下面就是一些切片的列子。
列如我们从range函数1-100中取7的倍数,函数及结果如下所示:
>>> for i in range(1,100)[6::7]: print i 7 14 21 28 35 42 49 56 63 70 77 84 91 98
取一个list或tuple的部分元素是非常常见的操作。比如,一个list如下:
>>> L = [‘Michael‘, ‘Sarah‘, ‘Tracy‘, ‘Bob‘, ‘Jack‘]
取前3个元素,应该怎么做?
笨办法:
>>> [L[0], L[1], L[2]] [‘Michael‘, ‘Sarah‘, ‘Tracy‘]
之所以是笨办法是因为扩展一下,取前N个元素就没辙了。
取前N个元素,也就是索引为0-(N-1)的元素,可以用循环:
>>> r = [] >>> n = 3 >>> for i in range(n): ... r.append(L[i]) ... >>> r [‘Michael‘, ‘Sarah‘, ‘Tracy‘]
对这种经常取指定索引范围的操作,用循环十分繁琐,因此,Python提供了切片(Slice)操作符,能大大简化这种操作。
对应上面的问题,取前3个元素,用一行代码就可以完成切片:
>>> L[0:3] [‘Michael‘, ‘Sarah‘, ‘Tracy‘]
L[0:3]
表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。
如果第一个索引是0,还可以省略:
>>> L[:3] [‘Michael‘, ‘Sarah‘, ‘Tracy‘]
也可以从索引1开始,取出2个元素出来:
>>> L[1:3] [‘Sarah‘, ‘Tracy‘]
类似的,既然Python支持L[-1]
取倒数第一个元素,那么它同样支持倒数切片,试试:
>>> L[-2:] [‘Bob‘, ‘Jack‘] >>> L[-2:-1] [‘Bob‘]
记住倒数第一个元素的索引是-1
。
切片操作十分有用。我们先创建一个0-99的数列:
>>> L = range(100) >>> L [0, 1, 2, 3, ..., 99]
可以通过切片轻松取出某一段数列。比如前10个数:
>>> L[:10]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
后10个数:
>>> L[-10:]
[90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
前11-20个数:
>>> L[10:20]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
前10个数,每两个取一个:
>>> L[:10:2]
[0, 2, 4, 6, 8]
所有数,每5个取一个:
>>> L[::5]
[0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95]
甚至什么都不写,只写[:]
就可以原样复制一个list:
>>> L[:]
[0, 1, 2, 3, ..., 99]
tuple也是一种list,唯一区别是tuple不可变。因此,tuple也可以用切片操作,只是操作的结果仍是tuple:
>>> (0, 1, 2, 3, 4, 5)[:3]
(0, 1, 2)
字符串‘xxx‘
或Unicode字符串u‘xxx‘
也可以看成是一种list,每个元素就是一个字符。因此,字符串也可以用切片操作,只是操作结果仍是字符串:
>>> ‘ABCDEFG‘[:3] ‘ABC‘ >>> ‘ABCDEFG‘[::2] ‘ACEG‘
还有一种切片中取切片就像C语言中的二维数组一样,但是比C语言中的二维数组要高级,具体如下例子所示:
>>> for i in range(1,100)[2::3][-10:]: print i 72 75 78 81 84 87 90 93 96 99
就是利用range函数生成1-100的数,然后我们取3的倍数,并且去最后十个。
下面同样是去3的倍数,不过是取前十个。
>>> for i in range(1,100)[2::3][:10]: print i 3 6 9 12 15 18 21 24 27 30
通过上面的例子我们看到python中的切片功能的强大,希望以后多进行运用。
在很多编程语言中,针对字符串提供了很多各种截取函数,其实目的就是对字符串切片。Python没有针对字符串的截取函数,只需要切片一个操作就可以完成,非常简单。
小结
有了切片操作,很多地方循环就不再需要了。Python的切片非常灵活,一行代码就可以实现很多行循环才能完成的操作。
以上是关于如何用Python字符串进行切片操作?的主要内容,如果未能解决你的问题,请参考以下文章