上一章Python教程请查看:python数值类型用法及其操作函数
字符串是Python中最流行的类型之一,我们可以通过在引号中包含字符来创建它们,Python将单引号等同于双引号,创建字符串与为变量赋值一样简单例如:
var1 = 'Hello World!'
var2 = "Python"
1、访问字符串中的值
Python不支持字符类型,这些字符串被视为长度为1的字符串,因此也被视为子字符串。
若要访问子字符串,请使用方括号将其与索引一起切片以获得子字符串。
#!/usr/bin/python
var1 = 'Hello World!'
var2 = "Python Programming"
print "var1[0]: ", var1[0]
print "var2[1:5]: ", var2[1:5]
2、更新字符串
你可以通过(重新)将一个变量赋值给另一个字符串来“更新”现有的字符串,新值可以与之前的值相关,也可以与完全不同的字符串相关。
#!/usr/bin/python
var1 = 'Hello World!'
print "更新字符串 :- ", var1[:6] + 'Python'
3、转义字符
下表是可以用反斜杠符号表示的转义字符或不可打印字符的列表。
转义字符被解释,在单引号和双引号字符串中。
反斜杠符号 | 十六进制字符 | 描述 |
\a | 0x07 | 铃声或警报 |
\b | 0x08 | 退格 |
\cx | Control-x | |
\C-x | Control-x | |
\e | 0x1b | Escape |
\f | 0x0c | 跳页 |
\M-\C-x | Meta-Control-x | |
\n | 0x0a | 新行 |
\nnn | 八进制 | |
\r | 0x0d | 回车 |
\s | 0x20 | 空格 |
\t | 0x09 | Tab |
\v | 0x0b | Vertical tab |
\x | Character x | |
\xnn | 十六进制表示法 |
4、字符串特殊操作符
假设字符串变量a表示“Hello”,变量b表示“Python”
操作符 | 说明 | 例子 |
+ | 连接——在操作符的任意一侧添加值 | a + b => HelloPython |
* | 重复——创建新的字符串,连接同一字符串的多个副本 | a*2 => -HelloHello |
[] | Slice—给出给定索引中的字符 | a[1] => e |
[ : ] | 范围切片——给出给定范围内的字符 | a[1:4] => ell |
in | 成员关系—如果给定字符串中存在字符,则返回true | H in a => 1 |
not in | 如果给定字符串中不存在字符,则返回true | M not in a => 1 |
r/R | 原始字符串—取消转义字符的实际含义。原始字符串的语法与普通字符串完全相同,只是原始字符串操作符“r”位于引号之前。“r”可以是小写(r)或大写(r),并且必须放在第一个引号之前。 | print r’\n’ prints \n and print R’\n’prints \n |
% | 格式化字符串 |
5、字符串格式化操作符
Python最酷的特性之一是字符串格式操作符%,这个操作符是字符串所特有的,它弥补了C的printf()家族函数的不足,下面是一个简单的例子
#!/usr/bin/python
print "name: %s and weight: %d kg!" % ('Oreja', 21)
以下是可以与%一起使用的完整符号集列表
格式化字符 | 转换 |
%c | 字符 |
%s | 格式化之前通过str()进行的字符串转换 |
%i | 有符号十进制整数 |
%d | 有符号十进制整数 |
%u | 无符号十进制整数 |
%o | 八进制整数 |
%x | 十六进制整数(小写字母) |
%X | 十六进制整数(大写字母) |
%e | 指数符号(小写e) |
%E | 指数符号(大写“E”) |
%f | 浮点实数 |
%g | %f和%e的简写 |
%G | %f和%E的简写 |
下表列出了其他受支持的符号和功能
符号 | 功能 |
* | 参数指定宽度或精度 |
– | 向左调整 |
+ | 显示符号 |
<sp> | 在正数前留空 |
# | 根据使用的是“x”还是“x”,将八进制前导0(“0”)或十六进制前导“0x”或“0x”相加。 |
0 | 从左向左填充0(而不是空格) |
% | ‘%%’只剩下一个文字’%’ |
(var) | 映射变量(字典参数) |
m.n. | m是最小总宽度,n是小数点后要显示的位数。 |
6、三重引号
Python的三重引号允许字符串跨越多行,包括逐字换行、制表符和任何其他特殊字符,从而起到了更大的作用。
三引号的语法由三个连续的单引号或双引号组成。
#!/usr/bin/python
para_str = """one
123456848
\tTwo\n
up.
"""
print para_str
注意每个特殊字符是如何被转换成打印形式的,一直到“up.”和结束三重引号之间的字符串末尾的最后一行换行符,还要注意换行时要么在行尾显式返回一个回车,要么使用转义码(\n)。
原始字符串根本不将反斜杠视为特殊字符,在原始字符串中放入的每个字符都保持原样
#!/usr/bin/python
print 'C:\\nowhere'
现在让我们使用原始字符串,我们将表达式放入r’expression’中,如下所示
#!/usr/bin/python
print r'C:\\nowhere'
7、Unicode字符串
Python中的普通字符串在内部存储为8位ASCII,而Unicode字符串存储为16位Unicode,这使得字符集更加多样化,包括来自世界上大多数语言的特殊字符。我将把对Unicode字符串的处理限制在以下范围内
#!/usr/bin/python
print u'Hello, world!'
可以看到Unicode字符串使用前缀u,就像原始字符串使用前缀r一样。
8、内置字符串操作函数
Python包含以下用于操作字符串的内置方法
编号 | 函数和说明 |
1 |
capitalize() 将字符串的第一个字母大写 |
2 |
center(width, fillchar) 返回一个空格填充的字符串,初始字符串以宽度列为中心。 |
3 |
count(str, beg= 0,end=len(string)) 计算在给定起始索引请求和结束索引结束的情况下,str在字符串或字符串的子字符串中出现的次数。 |
4 |
decode(encoding=’UTF-8′,errors=’strict’) 使用注册编码的编解码器对字符串进行解码。编码默认为默认字符串编码。 |
5 |
encode(encoding=’UTF-8′,errors=’strict’) 返回字符串的编码版本;在出现错误时,默认情况下会抛出一个ValueError,除非错误是用“忽略”或“替换”给出的。 |
6 |
endswith(suffix, beg=0, end=len(string)) 确定字符串或字符串的子字符串(如果给定起始索引请求和结束索引结束)是否以后缀结尾;如果是则返回true,否则返回false。 |
7 |
expandtabs(tabsize=8) 将字符串中的制表符展开为多个空格;如果没有提供选项卡大小,则默认为每个选项卡8个空格。 |
8 |
find(str, beg=0 end=len(string)) 判断str是出现在字符串中还是字符串的子字符串中,如果起始索引求值,则返回结束索引,如果找到则返回结束索引,否则返回-1。 |
9 |
index(str, beg=0, end=len(string)) 与find()相同,但如果没有找到str,则引发异常。 |
10 |
isalnum() 如果字符串至少有一个字符,并且所有字符都是字母数字,否则返回true。 |
11 |
isalpha() 如果字符串至少有一个字符,并且所有字符都是按字母顺序排列的,则返回true,否则返回false。 |
12 |
isdigit() 如果字符串只包含数字,则返回true,否则返回false。 |
13 |
islower() 如果字符串至少有一个大小写字符,并且所有大小写字符都是小写的,否则返回true。 |
14 |
isnumeric() 如果unicode字符串只包含数字字符,则返回true,否则返回false。 |
15 |
isspace() 如果字符串只包含空白字符,则返回true,否则返回false。 |
16 |
istitle() 如果字符串正确地“titlecated”,则返回true,否则返回false。 |
17 |
isupper() 如果字符串至少有一个大小写字符,并且所有大小写字符都是大写的,则返回true,否则返回false。 |
18 |
join(seq) 使用分隔符字符串将序列seq中的元素的字符串表示形式合并到一个字符串中。 |
19 |
len(string) 返回字符串的长度 |
20 |
ljust(width[, fillchar]) 返回一个空格填充的字符串,初始字符串左对齐到宽度列的总和。 |
21 |
lower() 将字符串中的所有大写字母转换为小写字母。 |
22 |
lstrip() 删除字符串中的所有前导空格。 |
23 |
maketrans() 返回要在翻译函数中使用的翻译表。 |
24 |
max(str) 从字符串str中返回最大字母字符。 |
25 |
min(str) 返回字符串str中的最小字母字符。 |
26 |
replace(old, new [, max]) 将字符串中所有旧值替换为新值,如果给定最大值,则最多替换最大值。 |
27 |
rfind(str, beg=0,end=len(string)) 与find()相同,但是在字符串中向后搜索。 |
28 |
rindex( str, beg=0, end=len(string)) 与index()相同,但在字符串中向后搜索。 |
29 |
rjust(width,[, fillchar]) 返回一个空格填充的字符串,初始字符串右对齐到宽度列的总和。 |
30 |
rstrip() 删除字符串的所有尾随空白。 |
31 |
split(str=””, num=string.count(str)) 根据分隔符str(如果没有提供空格)分隔字符串并返回子字符串列表;如果给定,最多分成num子字符串。 |
32 |
splitlines( num=string.count(‘\n’)) 在所有(或num)换行处拆分字符串,并返回删除换行后的每行的列表。 |
33 |
startswith(str, beg=0,end=len(string)) 确定字符串或字符串的子字符串(如果给定起始索引请求和结束索引结束)是否以子字符串str开头;如果是则返回true,否则返回false。 |
34 |
strip([chars]) 对字符串同时执行lstrip()和rstrip()。 |
35 |
swapcase() 反转字符串中所有字母的大小写。 |
36 |
title() 返回字符串的“titlecated”版本,即所有单词都以大写开头,其余都是小写。 |
37 |
translate(table, deletechars=””) 根据翻译表str(256字符)翻译字符串,删除del字符串中的字符。 |
38 |
upper() 将字符串中的小写字母转换为大写字母。 |
39 |
zfill (width) 返回用0填充的原始字符串到宽度字符的总数;用于数字,zfill()保留给定的任何符号(小于1个0)。 |
40 |
isdecimal() 如果unicode字符串只包含十进制字符,则返回true,否则返回false。 |
来源:
https://www.srcmini02.com/2447.html