脚本专栏 发布日期:2025/2/24 浏览次数:1
python字符串
字符串是 Python 中最常用的数据类型。我们可以使用引号('或")来创建字符串。
创建字符串很简单,只要为变量分配一个值即可。例如:
var1 = 'Hello World!' var2 = "jb51.net"
上面单引号'或双引号"都可以使用
Python 访问字符串中的值
Python 不支持单字符类型,单字符在 Python 中也是作为一个字符串使用。
Python 访问子字符串,可以使用方括号来截取字符串,如下实例:
#!/usr/bin/python3 var1 = 'Hello World!' var2 = "jb51.net" print ("var1[0]: ", var1[0]) print ("var2[1:5]: ", var2[1:5])
以上实例执行结果:
var1[0]: H
var2[1:5]: b51.
具体的查看这篇文章
https://www.jb51.net/article/165463.htm
Python 字符串更新
你可以截取字符串的一部分并与其他字段拼接,如下实例:
#!/usr/bin/python3 var1 = 'Hello World!' print ("已更新字符串 : ", var1[:6] + 'jb51.net')
var1[:6]就是截取var1从开始到第六个字符包括空格正好是"Hello "
以上实例执行结果
已更新字符串 : Hello jb51.net
Python转义字符
在需要在字符中使用特殊字符时,python用反斜杠(\)转义字符。如下表:
转义字符
描述
\(在行尾时)
续行符
\ 反斜杠符号
\'
单引号
\"
双引号
\a
响铃
\b
退格(Backspace)
\000
空
\n
换行
\v
纵向制表符
\t
横向制表符
\r
回车
\f
换页
\oyy
八进制数,yy 代表的字符,例如:\o12 代表换行,其中 o 是字母,不是数字 0。
\xyy
十六进制数,yy代表的字符,例如:\x0a代表换行
\other
其它的字符以普通格式输出
Python字符串运算符
下表实例变量a值为字符串 "Hello",b变量值为 "Python":
print( r'\n' ) print( R'\n' )
#!/usr/bin/python3 a = "Hello" b = "Python" print("a + b 输出结果:", a + b) print("a * 2 输出结果:", a * 2) print("a[1] 输出结果:", a[1]) print("a[1:4] 输出结果:", a[1:4]) if( "H" in a) : print("H 在变量 a 中") else : print("H 不在变量 a 中") if( "M" not in a) : print("M 不在变量 a 中") else : print("M 在变量 a 中") print (r'\n') print (R'\n')
以上实例输出结果为:
a + b 输出结果: HelloPython
a * 2 输出结果: HelloHello
a[1] 输出结果: e
a[1:4] 输出结果: ell
H 在变量 a 中
M 不在变量 a 中
\n
\n
Python字符串格式化
Python 支持格式化字符串的输出 。尽管这样可能会用到非常复杂的表达式,但最基本的用法是将一个值插入到一个有字符串格式符 %s 的字符串中。
在 Python 中,字符串格式化使用与 C 中 sprintf 函数一样的语法。
#!/usr/bin/python3 print ("我叫 %s 今年 %d 岁!" % ('', 13))
以上实例输出结果:
我叫 今年 13 岁!
python字符串格式化符号:
格式化操作符辅助指令:
Python2.6 开始,新增了一种格式化字符串的函数 str.format(),它增强了字符串格式化的功能。
Python三引号
python三引号允许一个字符串跨多行,字符串中可以包含换行符、制表符以及其他特殊字符。实例如下
#!/usr/bin/python3 para_str = """这是一个多行字符串的实例 多行字符串可以使用制表符 TAB ( \t )。 也可以使用换行符 [ \n ]。 """ print (para_str)
以上实例执行结果为:
这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( )。
也可以使用换行符 [
]。
三引号让程序员从引号和特殊字符串的泥潭里面解脱出来,自始至终保持一小块字符串的格式是所谓的WYSIWYG(所见即所得)格式的。
一个典型的用例是,当你需要一块HTML或者SQL时,这时用字符串组合,特殊字符串转义将会非常的繁琐。
errHTML = '''
<HTML><HEAD><TITLE>
Friends CGI Demo</TITLE></HEAD>
<BODY><H3>ERROR</H3>
<B>%s</B><P>
<FORM><INPUT TYPE=button VALUE=Back
ONCLICK="window.history.back()"></FORM>
</BODY></HTML>
'''
cursor.execute('''
CREATE TABLE users (
login VARCHAR(8),
uid INTEGER,
prid INTEGER)
''')
f-string
f-string 是 python3.6 之后版本添加的,称之为字面量格式化字符串,是新的格式化字符串的语法。
之前我们习惯用百分号 (%):
> name = 'Jb51.net' > 'Hello %s' % name 'Hello Jb51.net'
f-string 格式话字符串以 f 开头,后面跟着字符串,字符串中的表达式用大括号 {} 包起来,它会将变量或表达式计算后的值替换进去,实例如下:
> name = 'Jb51.net' > f'Hello {name}' # 替换变量 Hello jb51.net > f'{1+2}' # 使用表达式 '3' > w = {'name': 'Jb51', 'url': 'www.Jb51.net'} > f'{w["name"]}: {w["url"]}' 'Jb51: www.Jb51.net
用了这种方式明显更简单了,不用再去判断使用 %s,还是 %d。
在 Python 3.8 的版本中可以使用 = 符号来拼接运算表达式与结果:
实例
> x = 1 > print(f'{x+1}') # Python 3.6 2 > x = 1 > print(f'{x+1=}') # Python 3.8 'x+1=2'
Unicode 字符串
在Python2中,普通字符串是以8位ASCII码进行存储的,而Unicode字符串则存储为16位unicode字符串,这样能够表示更多的字符集。使用的语法是在字符串前面加上前缀 u。
在Python3中,所有的字符串都是Unicode字符串。
Python 的字符串内建函数
Python 的字符串常用内建函数如下:
capitalize()
将字符串的第一个字符转换为大写
center(width, fillchar)
count(str, beg= 0,end=len(string))
bytes.decode(encoding="utf-8", errors="strict")
encode(encoding='UTF-8',errors='strict')
endswith(suffix, beg=0, end=len(string))
检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
expandtabs(tabsize=8)
find(str, beg=0, end=len(string))
index(str, beg=0, end=len(string))
isalnum()
isalpha()
isdigit()
islower()
isnumeric()
isspace()
istitle()
isupper()
join(seq)
len(string)
ljust(width[, fillchar])
lower()
lstrip()
maketrans()
max(str)
min(str)
replace(old, new [, max])
rfind(str, beg=0,end=len(string))
rindex( str, beg=0, end=len(string))
rjust(width,[, fillchar])
rstrip()
split(str="", num=string.count(str))
splitlines([keepends])
startswith(substr, beg=0,end=len(string))
strip([chars])
swapcase()
title()
translate(table, deletechars="")
upper()
zfill (width)
isdecimal()
下面是不一些实例
建议大家手工打出来,这样才能理解,一个字符的差别都会导致出错
字符串截取字符补充:
# 0、a,b为参数。从字符串指针为a的地方开始截取字符,到b的前一个位置(因为不包含b) var1 = "hello world"; print(var1[a: b]); # 1、如果a,b均不填写,默认取全部字符。即,下面这两个打印结果是一样的 print(var1[: ]); # hello world print(var1); # hello world # 2、如果a填写,b不填写(或填写的值大于指针下标),默认从a开始截取,至字符串最后一个位置 print(var1[3: ]); # lo world # 3、如果a不填写, b填写,默认从0位置开始截取,至b的前一个位置 print(var1[: 8]); # hello wo # 4、如果a为负数,默认从尾部某一位置,开始向后截取 print(var1[-2: ]); # ld # 5、如果a>=b, 默认输出为空。 print(var1[3: 3]); print(var1[3: 2]);
python字符串格式化符号 %f 可指定小数点后的精度。
> num=18.7254 > print("the price is %.2f" %num) the price is 18.73 >
python字符串格式化符号:
%g 是 %f 和 %e 的简写是什么意思?到底是 %f 还是 %e?
对此我用代码测试了一下:
> a=100000 > print("%g"%(a)) 100000 > a=10000000 > print("%g"%(a)) 1e+07 > a=1000000 > print("%g"%(a)) 1e+06
可以发现,%g 是自动选择输出格式的,在六位数的情况下就会以科学计数法方式输出,文章中说 %g 是 %f 和 %e 的简写,但是我发现上述不是科学计数法方式输出的时候输出的是一个整数,于是又进行了如下测试:
> a=100000.0 > print("%g"%(a)) 100000 > print("%f"%(a)) 100000.000000 >
发现 %g 在不是用 %e 输出的情况下和%f还是有区别的
对此我又做了如下测试:
> a=100000.1 > print("%g"%(a)) 100000 > a=1.0 > print("%g"%(a)) 1 > a=1.1 > print("%g"%(a)) 1.1
发现在 a=100000.1 的时候输出的数并没有小数点后面的 1,对此我对比了 C 语言 %g 的格式输出,猜想 python 中应该如同 C 语言一样,%g 用于打印数据时,会去掉多余的零,至多保留六位有效数字。
使用格式化符号进行进制转换
> num=10 > print('十六进制:%#x' % num) #使用%x将十进制num格式化为十六进制 十六进制:0xa > print('二进制:', bin(num)) #使用bin将十进制num格式化为二进制 二进制: 0b1010 > print('八进制:%#o' % num) #使用%o将十进制num格式化为八进制 八进制:0o12
上面使用格式化符号进行进制转换中,多加入了一个#号,目的是在转换结果头部显示当前进制类型,如不需要,可将#号去除,如下
> print('八进制:%o' % num) 八进制:12 > print('十六进制:%x' % num) 十六进制:a
字符串截取字符继续补充:
[::2] 表示的是从头到尾,步长为2。第一个冒号两侧的数字是指截取字符串的范围,第二个冒号后面是指截取的步长。
> L=['a','b','c','d','e','f','g'] > print(L[::2]) ['a', 'c', 'e', 'g']
可以使用负数从字符串右边末尾向左边反向索引,最右侧索引值是 -1:
> str = "jb51.net" > str[-4] '.' >
字符串的分割还有partition()这种方式。
partition(sep) --> (head,sep,tail)
从左向右遇到分隔符把字符串分割成两部分,返回头、分割符、尾三部分的三元组。如果没有找到分割符,就返回头、尾两个空元素的三元组。
s1 = "I'm a good sutdent." #以'good'为分割符,返回头、分割符、尾三部分。 s2 = s1.partition('good') #没有找到分割符'abc',返回头、尾两个空元素的元组。 s3 = s1.partition('abc') print(s1) print(s2) print(s3)
结果如下:
I'm a good sutdent.
("I'm a ", 'good', ' sutdent.')
("I'm a good sutdent.", '', '')
字符串等倒序小测:
ch = "欢迎您" ls = [0, 1, 2, 3, 4] st = (0, 1, 2, 3, 4) print(ch[::-1]) print(ls[::-1]) print(st[::-1])
输出:
您迎欢家之本脚
[4, 3, 2, 1, 0]
(4, 3, 2, 1, 0)
这篇文章就介绍到这了。