字符串(string)

python3中变量可以不用设置变量类型,各种类型可以相互转化。可能这就是字符串使用如此灵活的一个原因。以下介绍一些基本概念,详细细节参见对应参考资料。

字符串的一些基本操作

如何表示字符串类型:使用单引号('),双引号( "),三引号('''或""") 对文本进行包裹就能得到字符串。

可以用+对字符串进行拼接以及*对字符串进行复制并拼接至原字符串末尾。

与C语言中字符串相似,python的字符串也可通过索引访问单个字符。还可以通过切片操作访问某个区间内数据。

字符串提供的一些字符串方法

len()用于返回字符串长度。

split(sep=None, maxsplit=-1)需要分别传入两个参数界定字符串和最大分割次数。

当maxsplit为-1表示无限次分割,否则将字符串按照界定字符串分割maxsplit次。

关于sep不为空的时候,按照给定的sep对字符串进行分割;当待分割的字符串是空字符串时,返回的列表是['']。

对于参考资料中的例子:运行'1,,2'.split(','),得到['1', '', '2']

可以这样理解,split函数从左到右按照sep对字符串进行分割,并将分割后得到的字符左侧放入返回列表中,之后再对字符串右边用sep进行分割。

关于sep为空时,将按照连续的空格进行分割字符串,并且不返回空字符串。

replace(old, new[, count])用old为原字符串中待替换的字符串,用new表示的新的字符串做替换,并返回一个替换后的拷贝字符串。[, count]中[ ]的含义是可选参数。count参数是控制替换操作需要进行几次。

以下是一些程序。

# PAT中的基础编程题目集函数题7-2

time, passtime = input().split(' ') # 将读入的字符串按空格进行分割,并赋值

hour = int(time) // 100 # 将字符串类型转化为整型,并做整数运算

min = int(time) % 100

endtime = hour * 60 + min + int(passtime)

endtime = endtime // 60 * 100 + endtime % 60

print(endtime)

# PAT中的基础编程题目集函数题7-31

# 解题思路:只要考虑小于字符串长度的移位操作,同时考虑到移位只是将前几个连续字符接到原字符串尾

# 因为等于字符长度的移位操作就是字符本身

# 需要得到小于字符串长度的的移位操作,只需要取余

# 移位操作可用切片操作完成

Str = input()

n = eval(input()) % len(Str) # 将读入字符串作为python语句运行,将运行结果用字符长度取余

print(Str[n: ] + Str[ : n]) # 对字符串进行切片

列表(list)

python3中的list有较多的操作以及函数,以下简单罗列部分,更多内容参见对应参考资料

列表的一些基本操作

列表的表示:用[和]包裹数据,列表中的元素用,分隔。

列表的创建:s = [ ]创建空列表,s = ['a', 'b' ]创建含有两个字符的列表。

使用in或not in 判断元素是否在列表中;使用+对两个列表进行拼接;使用*对列表进行复制并拼接至原字符串末尾。

类似C++中的vector类型,列表可以通过索引访问单个元素,同时可以使用切片访问连续区域的若干元素。

关于列表的复制

newS = s仅仅是将newS的指向s的地址空间,因此s的改变都会影响newS。

newS = s[: ]则是将s中的所有元素放到newS指向的空间,因此s的改变并不会改变newS中的数据。

因此,在创建多维列表

关于遍历列表使用循环语句即可。

列表的一些函数

append(x)在列表之后添加一个新的元素x,保持列表中数据类型的一致,如果不同可以根据IDE提示更改为set或tuple类型。

pop([i])弹出第i个元素,其中i为可选参数,未传入参数时默认为i = -1。

reverse()用于将列表自身反序,与s[: : -1](在文末讨论)的返回值相同。

len()返回列表长度。

以下是程序

# PAT中的基础编程题目集函数题7-6

listdata = input()

listdata = listdata.split(' ')

print('%c %d %.2f %.2f' %(listdata[2], int(listdata[1]), float(listdata[0]), float(listdata[3])))

# 其中float()将其转换为浮点类型

关于切片(slice)

s[i:j:k][i, j)区间内每隔k的元素组成的新列表.当i为None时为0,j为None时为len(s)。其中的k不能为0。

再说明一下各个字母的含义:i表示起始位置,j表示终止位置后一位,k表示间隔。

如执行s = [1, 2, 3, 4, 5, 6]和print(s[0: 3: 2]),得到[1, 3]。

该过程可以直观的理解为:

当k > 0时,返回[i, j)区间内每隔k的元素组成的新列表。

当k < 0时,

当i(j)为负数时,i = len(s) + i(j = len(s) + j)。

当i为None时为len(s) - 1;j为None时为-1。

当j+1 > i+1时,返回空列表;否则进入4。

完成上述判断之后,取原列表[j+1, i+1)区间内的元素后逆序得到新列表,之后在新列表中选取间隔-k的元素组成作为结果的列表。

关于第七份参考资料

s = [1, 2, 3, 4, 5, 6, 7, 8, 9]

print(s[: : -1])

print(s[5: 1: -2])

print(s[-1: -3: -1])

print(s[-3: : -1])

print(s[: -1: -1])

# 运行结果

# [9, 8, 7, 6, 5, 4, 3, 2, 1]

# [6, 4]

# [9, 8]

# [7, 6, 5, 4, 3, 2, 1]

# []

以第三个为例,

i和j不是None,但为负。则令i = len(s) + (-1) = 9 - 1 = 8;同理,j = 6。

取原列表中[j+1, i+1)的子列表,得到[8, 9];在做逆序操作,得到[9, 8]。

按间隔k = 1组成返回的列表,即[9, 8]。

参考