欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Python數(shù)據(jù)類型、進制轉換、字符串格式化的問題

 更新時間:2022年04月28日 11:57:36   作者:這個手剎不太靈兒  
這篇文章主要介紹了Python數(shù)據(jù)類型、進制轉換、字符串格式化,Python2中區(qū)分整型int、長整型long,Python3中只有統(tǒng)稱為整型int,本文給大家介紹的非常詳細,需要的朋友參考下吧

1. 整數(shù)、浮點數(shù)和復數(shù)

Python2中區(qū)分整型int、長整型long
Python3中只有統(tǒng)稱為 整型int

浮點數(shù)

即帶有小數(shù)點的數(shù)字,因為浮點數(shù)用二進制表示的,小數(shù)部分有時是無法表示的。是不精確的

float組成: 由整數(shù)位,小數(shù)點,小數(shù)位組成,也可以用科學計數(shù)法表示

Decimal

是精確的

from decimal import Decimal  #從decimal 包導入Decimal  類
mydec = Decimal("3.22")   #將字符串轉換成decimal類型
print(mydec, type(mydec))
mydec2 = Decimal(3.22)   #浮點型3.22 是不精確的,轉換成decimal就是精確的
print(mydec2, type(mydec))

結果:3.22 <class 'decimal.Decimal'>
3.220000000000000195399252334027551114559173583984375 <class 'decimal.Decimal'>

復數(shù)

dir(a) 查看屬性
a.imag 獲取虛部,無論定義的時候是整型還是浮點型最終都會轉換成浮點型
a.real 獲取實部

>>> a = 4 + 5j
>>> a.imag
5.0
>>> a.real
4.0

2.進制轉換

進制數(shù)字類型

二進制、八進制、十六進制都是整型

>>> a=0b11  二進制   binary
>>> type(a)  
<class 'int'>  
>>> b=0o11  八進制 octonary
>>> type(b)
<class 'int'> 
>>> c=0x11 十六制   hexadecimal
>>> type(c)
<class 'int'> 

整型進制操作

整型轉換成2、8、16進制,得到的值是字符串類型

>>> num = 100
>>> bin(num)  整型轉換成二進制,()里面只能是整型
              任意進制轉2進制, 接收一個int, 返回一個str
'0b1100100'   
>>> oct(num) 任意進制轉8進制, 接收一個int, 返回一個str
'0o144'
>>> hex(num)   任意進制轉16進制, 接收一個int, 返回一個str
'0x64'
>>> int (0o11) 接收整型 
9
>>> int("0o11",base=8) 接收整型,但要指定幾進制
9
>>> int("11")  接收整型,可以不指定,因為它是一個數(shù)字
11

3. 字符串

3.1 轉義字符

r標志:是輸出原始字符串,不轉義

3.2 字符串取值

下標取值法
從左0123456
從右-1 -2 -3 -4 -5

>>> a = 'abcdefghijklmnopq'
>>> a[0]
'a'
>>> a[-8]
'j'

切片取值法

str[start:end:step]       左閉右開
step 為正數(shù) 從左至右
step 為負數(shù) 從右至左
str[2:]  從左至右 第三個數(shù)開始
str[:7] 從左至右到第七位
str[::-1]  從右至左 步長為1
str[4::-2]  從第五個數(shù)開始從右至左 步長為2
>>> a = 'abcdefghijklmnopq'  一旦定義不可改變
>>> a[2:5]
'cde'

4. 字符串運算與轉換

>>> str1="qqq"
>>> str2 = "lll"
>>> str1+str2 # 字符串拼接
'qqqlll'
>>> str3="abc"  
>>> str3*3  
'abcabcabc'字符串復制
>>> result = str(100)  # int轉換成字符串
>>> type(result)
<class 'str'>
>>> result
'100'

5. 字符串的常用方法

判斷系列

演示:

>>> str7= "helloabc xx zz"
>>> str7.startswith("abc")
False
>>> str7.startswith("abc",5)
True
>>> str7.startswith("abc",5,7)
False
>>> str7.startswith("abc",5,8)
True

查找統(tǒng)計系列

len不是字符串的屬性方法,不能通過.len的方式去計算長度

字符串轉換類

>>> str7
'helloabc xx zz'
>>> str7.upper()  轉大寫
'HELLOABC XX ZZ'
>>> str7.title()  轉標題格式
'Helloabc Xx Zz'
>>> str9 = str7.title().swapcase()  大小寫互換
>>> str9
'hELLOABC xX zZ'
>>> str9 = "a b c d e f"
>>> str9.split()  默認按空格切割
['a', 'b', 'c', 'd', 'e', 'f']
>>> str10 = "a#b#c#d#e#f#g#h"
>>> str10.split("#")
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h']
>>> str11 = str10.split("#")
>>> str11
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h']
>>> "*".join(str11)
'a*b*c*d*e*f*g*h'

+和join的效率問題

+ 拼接效率比join低。+拼接,每一次出現(xiàn)都會在內存中開辟一個新的空間,所以效率低

6 . 字符串格式化

%格式化


語法格式:%[(name)][flags][width].[precision]typecode

  • (name):命名
  • flags: +,-,’ '或0。

+表示右對齊;-表示左對齊;
’ '為一個空格,表示在正數(shù)的左側填充一個空格,從而與負數(shù)對齊,0表示使用0填充。

  • width表示顯示寬度
  • precision表示小數(shù)點后精度

%s 一個蘿卜一個坑,一一對應,不能多也不能少

演示:

結果

format格式化

num1 = 0.1416926   #轉換成百分位
print("%.2f%% " % (num1 * 100))

f格式化

python2不支持這種寫法

print(f"my name is {name},my age is {age}")
結果:my name is sc,my age is 4  
print(f"my name is {name},my age is {age:*>10}")
結果:my name is sc,my age is *********4

練習

字符串的拼接方式
請計算出新拼接出來的字符串長度,并取出其中的第七個字符。

a = "字符串拼接1"
b = "字符串拼接2"
print("方式1:" + a + b)
print("方式2:%s%s" % (a, b))
print(f"方式3:{a}")
print("方式4:{0}{1}".format(a, b))
c = a + b
print("新拼接的字符串長度為:", len(c))
print("第七個字符為:", c[6])
str1 = "8*y*cali*china**it*soft*linux*python"
count = str1.count("*")
list = str1.split("*")
str2 = "".join(list)
print("*" * count + str2)

將字符串"8ycalichina**itsoftlinuxpython"里的所有的*號抽
取出來放到最前面,里面的字符串保持順序不變

str1 = "8*y*cali*china**it*soft*linux*python"
count = str1.count("*")
list = str1.split("*")
str2 = "".join(list)
print("*" * count + str2)

7. 字符串拼接

print(“%s %s”%(str1,str2))

>>> str1 = "你好" 
>>> str2 = "hejin"
>>> str1+str2    #方式1:加號拼接
'你好hejin'
>>> "".join([str1,str2])  #方式2:join拼接
'你好hejin'
>>> print("%s,%s"%(str1,str2))  #方式3:% 占位符
你好,hejin
>>> "{},{}".format(str1,str2)   #方式4:format()
'你好,hejin'
>>> "{0},{1}".format(str1,str2) # 方式5 
'你好,hejin'
>>> "{1},{0}".format(str1,str2)
'hejin,你好'
>>> "{a},".format(a=str1,b=str2)  # 方式6 
'你好,hejin'
>>> ",{a}".format(a=str1,b=str2)
'hejin,你好'
>>> f"{str1},{str2}"  # 方式7:f格式化
'你好,hejin'

練習:猜誰是小偷

嫌疑人A、B、C、D的筆錄如下,其中三人為真,一人為假:
a:我不是小偷
b:C是小偷
c:小偷肯定是D
d:小偷肯定是D
lst = ["a", "b", "c", "d"]
for x in lst:
    if ("a" != x) + ("c" == x) + ("d" == x) + ("d" != x) == 3:
        print(f"{x}是小偷")

到此這篇關于Python數(shù)據(jù)類型、進制轉換、字符串格式化的文章就介紹到這了,更多相關Python字符串格式化內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論