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 jb51.net

Pythonのエスケープ文字

あなたは、バックスラッシュ()エスケープ文字と文字、pythonで特殊文字を使用する必要がある場合。以下:ここに画像を挿入説明
Python文字列演算子を

例次の表は、変数、文字列「こんにちは」、変数「パイソン」のb値は次のとおりです。ここに画像を挿入説明
ここに画像を挿入説明

#!/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の文字列の書式記号:
ここに画像を挿入説明
:フォーマット演算子は、コマンド支援ここに画像を挿入説明
機能を書式文字列を高め、フォーマット文字列()、のPythonの2.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

数値は小数点の出力は、この私はC言語%gの出力の形式を比較し、Pythonの推測は、C言語は、%Gの印刷データと同じでなければならない、1でない場合、余分が除去され= 100000.1に見出さゼロは、6桁までに予約しました。

バイナリシンボルを使用してフォーマット変換

>>> 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(sep)  --> (head,sep,tail)

二つの部分、第一戻り、三部スプリットトリプレットシンボル、尾部に文字列を分割する右遭遇する区切り文字を左から。区切り文字が見つからない場合は、それが尾は2つの空の要素を3倍、頭を返します。

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スクリプト、爬虫類、ジャンゴ、データマイニング、技術をプログラミング、仕事の経験だけでなく、小型のpythonパートナーのシニア入念な研究から戦闘にゼロベースの情報のプロジェクトを仕上げ!時限プログラマPythonは日常の技術を説明している方法は、学習と細部への注意を払う必要性へのいくつかを共有します

公開された38元の記事 ウォン称賛13 ビュー40000 +

おすすめ

転載: blog.csdn.net/haoxun06/article/details/104505180