python 3 教程: 字符串知识点学习笔记

字符串是 Python 中最常用的数据类型。我们可以使用引号('或")来创建字符串
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用反斜杠()转义字符。如下表:在这里插入图片描述
Python字符串运算符

下表实例变量a值为字符串 “Hello”,b变量值为 “Python”:在这里插入图片描述
在这里插入图片描述

#!/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')

以上实例输出结果为:在这里插入图片描述
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 的字符串常用内建函数如下:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
下面是不一些实例

建议大家手工打出来,这样才能理解,一个字符的差别都会导致出错

字符串截取字符补充:

# 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)

结果如下:
在这里插入图片描述
字符串等倒序小测:

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)

推荐我们的python学习基地,点击进入,看老程序是如何学习的!从基础的python脚本、爬虫、django、数据挖掘等编程技术,工作经验,还有前辈精心为学习python的小伙伴整理零基础到项目实战的资料,!每天都有程序员定时讲解Python技术,分享一些学习的方法和需要留意的小细节

发布了38 篇原创文章 · 获赞 13 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/haoxun06/article/details/104505180