时间:2021-05-22
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.
具体的查看这篇文章
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":
操作符 描述 实例 + 字符串连接 a + b 输出结果: HelloPython * 重复输出字符串 a*2 输出结果:HelloHello [] 通过索引获取字符串中字符 a[1] 输出结果e [ : ] 截取字符串中的一部分,遵循左闭右开原则,str[0,2] 是不包含第 3 个字符的。 a[1:4] 输出结果ell in 成员运算符 - 如果字符串中包含给定的字符返回 True 'H' in a输出结果 True not in 成员运算符 - 如果字符串中不包含给定的字符返回 True 'M' not in a输出结果 True r/R 原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思来使用,没有转义特殊或不能打印的字符。 原始字符串除在字符串的第一个引号前加上字母r(可以大小写)以外,与普通字符串有着几乎完全相同的语法。 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字符串格式化符号:
符 号 描述 %c 格式化字符及其ASCII码 %s 格式化字符串 %d 格式化整数 %u 格式化无符号整型 %o 格式化无符号八进制数 %x 格式化无符号十六进制数 %X 格式化无符号十六进制数(大写) %f 格式化浮点数字,可指定小数点后的精度 %e 用科学计数法格式化浮点数 %E 作用同%e,用科学计数法格式化浮点数 %g %f和%e的简写 %G %f 和 %E 的简写 %p 用十六进制数格式化变量的地址
格式化操作符辅助指令:
符号 功能 * 定义宽度或者小数点精度 - 用做左对齐 + 在正数前面显示加号( + ) <sp> 在正数前面显示空格 # 在八进制数前面显示零('0'),在十六进制前面显示'0x'或者'0X'(取决于用的是'x'还是'X') 0 显示的数字前面填充'0'而不是默认的空格 % '%%'输出一个单一的'%' (var) 映射变量(字典参数) m.n. m 是显示的最小总宽度,n 是小数点后的位数(如果可用的话)
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.62>>> x = 1>>> print(f'{x+1=}') # Python 3.8'x+1=2'Unicode 字符串
在Python2中,普通字符串是以8位ASCII码进行存储的,而Unicode字符串则存储为16位unicode字符串,这样能够表示更多的字符集。使用的语法是在字符串前面加上前缀 u。
在Python3中,所有的字符串都是Unicode字符串。
Python 的字符串内建函数
Python 的字符串常用内建函数如下:
序号 方法及描述 1
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 worldprint(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)
这篇文章就介绍到这了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在最新的Python3版本中,字符串是以Unicode编码的,即Python的字符串支持多语言编码和解码 字符串在内存中以Unicode表示,在操作字符串时,
字符串操作在任意编程语言的日常编程中都随处可见,今天来汇总一下C#中关于字符串的一些你可能遗忘或遗漏的知识点。逐字字符串在普通字符串中,反斜杠字符是转义字符。而
1、据说python3就没有这个问题了2、u'字符串'代表是unicode格式的数据,路径最好写成这个格式,别直接跟字符串'字符串'这类数据相加,相加之后typ
本文实例形式讲解了Python3的条件与循环控制语句及其用法,是学习Python所必须掌握的重要知识点,现共享给大家供大家参考。具体如下:一般来说Python的
问题一:TypeError:abytes-likeobjectisrequired,not'str'解决:该问题属于Python3和Python2的字符串兼容问