日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python基本数据类型及操作

發布時間:2025/6/17 python 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python基本数据类型及操作 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

數字類型

數字類型分為整型,浮點型,布爾型

1.整型
num = -1000000000000000000000000000000000000000000000000
print(num, type(num))
-100000000000000000000000000 <class 'int'>

?

py2中小整數用int存放,大整數用long,而在py3中取消了長整型全部用int,數值過大的會被當作字符串保存。

2.小數
num = 3.14
print(num, type(num))
<class 'float'>

?

3.布爾
res = True
print(res, type(res), isinstance(res, int))
print(3.14 + True)

True <class 'bool'> True
4.140000000000001

?

重點:數字類型直接的相互轉化 *****
a = 10
b = 3.74
c = True
print(int(a), int(b), int(c))
print(float(a), float(b), float(c))
print(bool(a), bool(b), bool(c))

int只能將純數字轉化為整型

float只能將含有小數的數字轉化為浮點型

布爾型本質為0和1,0代表false1代表true.

字符串類型

1.定義: 可以有多種引號嵌套

需求:你是"好學生"
s1 = "你是\"好學生\""
print(s1)

你是"好學生"

-------------

s2 = '你是"好學生"'
print(s2)

你是"好學生"

單引號和雙引號可以互相嵌套,但開頭和結尾為單引號或雙引號時可以使用三引號

字符串的常規操作

1.字符串的索引取值: 字符串[index]

正向取值從0編號,反向取值從-1編號

s1 = '123abc呵呵'
print(id(s1)) # 2217572683576
print(s1[0], id(s1[0])) # 2217543167200
t_s = '1'
print(id(t_s)) # 2217543167200

2.字符串拼接

?s2 = '你好'

s22 = '帥'
ss2 = s2 + s22
print(ss2, id(s2), id(s22), id(ss2))

字符串可以直接拼接但是拼接后的字符串會開辟出新的內存來存儲

如果要拼接其他類型(str--字符串)

a = 10
b = "20"
c = True
res = "%s%s%s" % (a, b, c)? ? # 方法1
print(res)
res = str(a) + b + str(c)? ? ? ? ? ? # 方法2
print(res)

不同數據類型可以直接拼接但是必須要先轉換為字符串類型

?3.字符串長度

s3 = '12345'

ln1 = s3.__len__()
print(ln1)
ln2 = len(s3)
print(ln2)

5

5

?.__len__()作為魔法變量用來計算字符串長度

4.字符串切片: 取子字符串 - [::] - [start_index:end_index:step]
s4 = '123abc呵呵'
sub_s = s4[0:6:]
print(sub_s)?

123abc
sub_s = s4[0:6:2]
print(sub_s)?

13b
sub_s = s4[::-1]
print(sub_s)?

呵呵cba321
sub_s = s4[-1:-6:-1]
print(sub_s)?

呵呵cba

[開始索引:結束索引:步長]

步長為負的話會倒敘輸出

5.成員運算:判斷某字符串是否在該字符串中

s5 = '123abc呵呵'
ss5 = '12a'
print(ss5 in s5)? ? ? ? ? ? ?# False
print(ss5 not in s5)? ? ? ?# True

6.字符串循環(遍歷)

s6 = '123abc呵呵'
for v in s5:
print(v)

1
2
3
a
b
c

每次循環輸出字符串中的單個數值

重要方法

1.索引index(目標字符串的索引位置)
s1 = '123abc呵呵'
print(s1.index('b'))

4

index可以找出目標字符在字符串中的位置

?

2.去留白(默認去兩端留白,也可以去指定字符)

s2 = '***好 * 的 ***'
print(s2.strip('*'))

?

3.計算子字符串個數
s3 = '12312312'
print(s3.count('123'))

?

4.判斷字符串是否是數字:只能判斷正整數
s4 = '123'
print(s4.isdigit())

?

5.大小寫轉換
s5 = "AbC def"
print(s5.upper()) # 全大寫

ABC DEF
print(s5.lower()) # 全小寫

abc def
# 了了解
print(s5.capitalize()) # 首字母大寫

Abc def
print(s5.title()) # 每個單詞首字大寫

Abc Def

?

?6.以某某開頭或結尾

s6 = 'https://www.baidu.com'
r1 = s6.startswith('https:')#以https開頭
r2 = s6.startswith('http:')?
r3 = s6.endswith('com')? #以com結尾
r4 = s6.endswith('cn')
if (r1 or r2) and (r3 or r4):
print('合法的鏈接')
else:
print('非合法的鏈接')

?

7.替換
s7 = 'egon say: he is da shuai b,egon!egon!egon!'
new_s7 = s7.replace('egon', 'Liu某') # 默認替換所有
print(new_s7)
new_s7 = s7.replace('egon', 'Liu某', 1) # 替換一次
print(new_s7)

?

8.格式化
s8 = 'name:{},age:{}'
print(s8.format('Owen', 18)) # 默認按位置
print('name:{1},age:{1}, height:{1}'.format('Owen', 18)) # 標注位置,一個值可以多次利用
print('name:{n},age:{a}, height:{a}'.format(a=18, n="Zero")) # 指名道姓

?

1. find | rfind:查找子字符串索引,無結果返回-1
2. lstrip:去左留白
3. rstrip:去右留白
4. center | ljust | rjust | zfill:按位填充
語法:center(所占位數, '填充符號')
5. expandtabs:規定\t所占空格數
6. captialize | title | swapcase:首字母大寫 | 單詞首字母大寫 | 大小寫反轉
7. isdigit | isdecimal | isnumeric:數字判斷
8. isalnum | isalpha:是否由字母數字組成 | 由字母組成
9. isidentifier:是否是合法標識符
10. islower | isupper:是否全小 | 大寫
11. isspace:是否是空白字符
12. istitle:是否為單詞首字母大寫格式

?

列表類型

list中可以存放多個值,可以存放所有類型的數據

list中有序的,可以通過索引取值

1.索引取值: 列表名[index]
s1 = [1, 3, 2]
print(s1[0])
0
print(s1[-1])
2
在列表名后以[]的格式獲取相應位置的數值,查找的為負數時會從后往前查找 2.列表運算: 得到的是新list
s2 = [1, 2, 3]
print(s2 + s2)
[1, 2, 3, 1, 2, 3]
print(s2 * 2)
[1, 2, 3, 1, 2, 3]
print(s2)
[1, 2, 3]
列表可以相加,相加后列表內的數值會合并。列表做乘法運算之后數值會翻倍累加 .list的長度
s3 = [3, 4, 1, 2, 5]
print(len(s3))
5
len(list)可以計算出列表內數值的個數 4.切片:[start_index:end_index:step]
s4 = [3, 4, 1, 2, 5]
new_s4 = s4[::-1]
print(new_s4)
new_s4 = s4[1:4:]
print(new_s4)
new_s4 = s4[-2:-5:-1]
print(new_s4)
list切片的格式為 list[開始索引:結束索引:步長]

  步長為負的話會倒敘輸出

5.成員運算:in
s5 = [3, 4, '1', 2, 5]
print('1' in s5)
print(1 in s5)
print(5 not in s5)
判斷目標數值是否在列表中,輸出結果為布爾值 6.循環 s5 = [3, 4, '1', 2, 5] for v in s5:
print(v, type(v))

3 <class 'int'>
4 <class 'int'>
1 <class 'str'>
2 <class 'int'>
5 <class 'int'>



for v in s5:
if isinstance(v, int):
print(v, end=' ') 3 4 2 5?

列表操作

1.列表的增刪改查
ls = [1, 2, 3]


print(ls)
print(ls[1])
2 增
ls.append(0) # append可以在列表末尾增加‘0’
print(ls)
[1, 2, 3, 0]
ls.insert(1, 666) # insert可以在任意index前增
print(ls)

[1, 666, 2, 3, 0]
ls.insert(len(ls), 888) # insert實行末尾增
print(ls)
[1, 666, 2, 3, 0, 888] 改
ls[1] = 66666 #直接吧目標數字更改
print(ls)
[1, 66666, 2, 3, 0, 888] 刪
ls.remove(888) #直接刪除目標數值
print(ls)
res = ls.pop() # 默認從末尾刪,并返還刪除的值
print(res)
res = ls.pop(1) # 從指定索引刪除,并返還刪除的值
print(res, ls) 了了解
del ls[2] #del也可以指定索引刪除但還是不會返還值
print(res, ls)
# 清空
ls.clear()
print(ls) 排序: 針對于同類型
ls = ['3', '1', '2']
ls.sort() # 默認正向排序
print(ls)
['1', '2', '3']
ls.sort(reverse=True) # 正向排序結果上翻轉,形成倒序
print(ls)
['3', '2', '1'] 2)翻轉
ls = ['3', '1', '2']
ls.reverse() # 按存儲的順序進行翻轉
print(ls)
['2', '1', '3'] 計算值的個數 => 列表中可以存放重復數據
ls = [1, 2, 1, 2, 3, 1]
print(ls.count(1)) # 對象1存在的次數 整體增加,添加到末尾
ls = [1, 2, 3]
ls.extend('123')
print(ls)
ls.extend([0, 1, 2])
print(ls) 目標的索引位置,可以規定查找區間
ls = [1, 2, 1, 2, 3, 1]
# 找對象1,在索引3開始往后找到索引6之前
ind = ls.index(1, 3, 6)
print(ind)

可便于不可變類型

ls = [10, 20, 30]
print(id(ls), ls)
ls[0] = 100
print(id(ls), ls)

print(id(10))
print(id(20))
print(id(100))
print(id('100'))

?

?

轉載于:https://www.cnblogs.com/duGD/p/10726603.html

總結

以上是生活随笔為你收集整理的python基本数据类型及操作的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。