溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python有什么基本數據類型

發布時間:2021-10-18 15:54:37 來源:億速云 閱讀:141 作者:小新 欄目:編程語言

這篇文章主要介紹Python有什么基本數據類型,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

運算符

一、數字運算

Python有什么基本數據類型

二、比較運算

Python有什么基本數據類型

三、賦值運算

Python有什么基本數據類型

四、邏輯運算

Python有什么基本數據類型

五、成員運算

Python有什么基本數據類型

基本數據類型

一、數字

int(整型)

  在32位機器上,整數的位數為32位,取值范圍為-231~231-1,即-2147483648~2147483647
  在64位系統上,整數的位數為64位,取值范圍為-263~263-1,即-9223372036854775808~9223372036854775807

- int
    將字符串轉換為數字
        a = "123"
        print(type(a),a)

        b = int(a)
        print(type(b),b)

        num = "0011" 
        v = int(num, base=16)
        print(v)
- bit_lenght
        # 當前數字的二進制,至少用n位表示
        r = age.bit_length()

二、字符串

字符串一旦創建,不可修改
一旦修改或者拼接,都會造成重新生成字符串

字符串常用功能

  • join

  • split

  • find

  • strip

  • upper

  • lower

  • replace

# 1 首字母大寫
    # test = "aLex"
    # v = test.capitalize()
    # print(v)

# 2 所有變小寫,casefold更牛逼,很多未知的對相應變小寫
    # v1 = test.casefold()
    # print(v1)
    # v2 = test.lower()
    # print(v2)

# 3 設置寬度,并將內容居中
    # 20 代指總長度
    # *  空白未知填充,一個字符,可有可無
    # v = test.center(20,"中")
    # print(v)

    # test = "alex"
    # v = test.ljust(20,"*")
    # print(v)

    # test = "alex"
    # v = test.rjust(20,"*")
    # print(v)

    # test = "alex"
    # v = test.zfill(20)
    # print(v)

# 4 去字符串中尋找,尋找子序列的出現次數
    # test = "aLexalexr"
    # v = test.count('ex')
    # print(v)

    # test = "aLexalexr"
    # v = test.count('ex',5,6)
    # print(v)

# 5
    # 以什么什么結尾
    # 以什么什么開始
    # test = "alex"
    # v = test.endswith('ex')
    # v = test.startswith('ex')
    # print(v)

# 6 expandtabs,斷句20,
    # test = 
    # v = test.expandtabs(20)
    # print(v)

# 7 從開始往后找,找到第一個之后,獲取其未知
    # > 或 >=
    # test = "alexalex"
    # 未找到 -1
    # v = test.find('ex')
    # print(v)

# 8 index找不到,報錯   忽略
    # test = "alexalex"
    # v = test.index('8')
    # print(v)

# 9 格式化,將一個字符串中的占位符替換為指定的值
    # test = 'i am {name}, age {a}'
    # print(test)
    # v = test.format(name='alex',a=19)
    # print(v)

    # test = 'i am {0}, age {1}'
    # print(test)
    # v = test.format('alex',19)
    # print(v)

# 10 格式化,傳入的值 {"name": 'alex', "a": 19}
    # test = 'i am {name}, age {a}'
    # v1 = test.format(name='df',a=10)
    # v2 = test.format_map({"name": 'alex', "a": 19})

# 11 字符串中是否只包含 字母和數字
    # test = "123"
    # v = test.isalnum()
    # print(v)
    # str

# 12 是否是字母,漢子
    # test = "as2df"
    # v = test.isalpha()
    # print(v)

# 13 當前輸入是否是數字
    # test = "二" # 1,②
    # v1 = test.isdecimal()
    # v2 = test.isdigit()
    # v3 = test.isnumeric()
    # print(v1,v2,v3)

# 14 是否存在不可顯示的字符
    # \t   制表符
    # \n   換行
    # test = "oiuas\tdfkj"
    # v = test.isprintable()
    # print(v)

# 15 判斷是否全部是空格
    # test = ""
    # v = test.isspace()
    # print(v)

# 16 判斷是否是標題
    # test = "Return True if all cased characters in S are uppercase and there is"
    # v1 = test.istitle()
    # print(v1)
    # v2 = test.title()
    # print(v2)
    # v3 = v2.istitle()
    # print(v3)

# 17 ***** 將字符串中的每一個元素按照指定分隔符進行拼接
    # test = "你是風兒我是沙"
    # print(test)
    # # t = ' '
    # v = "_".join(test)
    # print(v)

# 18 判斷是否全部是大小寫 和 轉換為大小寫
    # test = "Alex"
    # v1 = test.islower()
    # v2 = test.lower()
    # print(v1, v2)

    # v1 = test.isupper()
    # v2 = test.upper()
    # print(v1,v2)
# 19
    # 移除指定字符串
    # 有限最多匹配
    # test = "xa"
    # # v = test.lstrip('xa')
    # v = test.rstrip('9lexxexa')
    # # v = test.strip('xa')
    # print(v)

    # test.lstrip()
    # test.rstrip()
    # test.strip()
    # 去除左右空白
    # v = test.lstrip()
    # v = test.rstrip()
    # v = test.strip()
    # print(v)
    # print(test)
    # 去除\t \n
    # v = test.lstrip()
    # v = test.rstrip()
    # v = test.strip()
    # print(v)

# 20 對應關系替換
    # test =  "aeiou"
    # test1 = "12345"

    # v = "asidufkasd;fiuadkf;adfkjalsdjf"
    # m = str.maketrans("aeiou", "12345")
    # new_v = v.translate(m)
    # print(new_v)

# 21 分割為三部分
    # test = "testasdsddfg"
    # v = test.partition('s')
    # print(v)
    # v = test.rpartition('s')
    # print(v)

# 22 分割為指定個數
    # v = test.split('s',2)
    # print(v)
    # test.rsplit()

# 23 分割,只能根據,true,false:是否保留換行
    # test = "asdfadfasdf\nasdfasdf\nadfasdf"
    # v = test.splitlines(False)
    # print(v)

#  24 以xxx開頭,以xx結尾
    # test = "backend 1.1.1.1"
    # v = test.startswith('a')
    # print(v)
    # test.endswith('a)

# 25 大小寫轉換
    # test = "aLex"
    # v = test.swapcase()
    # print(v)

# 26 字母,數字,下劃線 : 標識符 def  class
    # a = "def"
    # v = a.isidentifier()
    # print(v)

# 27 將指定字符串替換為指定字符串
    # test = "alexalexalex"
    # v = test.replace("ex",'bbb')
    # print(v)
    # v = test.replace("ex",'bbb',2)
    # print(v)
# 一、for循環
    # for 變量名 in 字符串:
    #     變量名
    # break
    # continue

    # index = 0
    # while index < len(test):
    #     v = test[index]
    #     print(v)
    #
    #     index += 1
    # print('=======')

    # for zjw in test:
    #     print(zjw)

    # test = "鄭建文妹子有種沖我來"
    # for item in test:
    #     print(item)
    #     break

    # for item in test:
    #     continue
    #     print(item)

# 二、索引,下標,獲取字符串中的某一個字符
    # v = test[3]
    # print(v)

# 三、切片
    # v = test[0:-1] # 0=<  <1
    # print(v)

# 四、獲取長度
    # Python3: len獲取當前字符串中由幾個字符組成
    # v = len(test)
    # print(v)

# 五、獲取連續或不連續的數字,
    # Python2中直接創建在內容中
    # python3中只有for循環時,才一個一個創建
    # r1 = range(10)
    # r2 = range(1,10)
    # r3 = range(1,10,2)
    # 幫助創建連續的數字,通過設置步長來指定不連續
    # v = range(0, 100, 5)
    #
    # for item in v:
    #     print(item)

三、列表

列表格式

  • 列表中可以嵌套任何類型

  • 中括號括起來

  • ,分割每個元素

  • 列表中的元素可以是 數字,字符串,列表,布爾值..所有的都能放進去

  • “集合”,內部放置任何東西

  • 列表,有序;元素可以被修改

#########################list類中提供的方法 #######################

# li = [11, 22, 33, 22, 44]
# 參數
# 1. 原來值最后追加
# 對象.方法(..)   # li對象調用append方法
# li.append(5)
# li.append("alex")
# li.append([1234,2323])
# print(li)

# 2 清空列表
# li.clear()
# print(li)

# 3 拷貝,淺拷貝
# v = li.copy()
# print(v)
# 4. 計算元素出現的次數
# v = li.count(22)
# print(v)

# 5. 擴展原列表,參數:可迭代對象
# li = [11, 22, 33, 22, 44]
# li.append([9898,"不得了"])
# [11, 22, 33, 22, 44, [9898, '不得了']]

# li.extend([9898,"不得了"])
# for i in [9898,"不得了"]:
#     li.append(i)
# [11, 22, 33, 22, 44, 9898, '不得了']
#
# li.extend("不得了")
# print(li)

# 6. 根據值獲取當前值索引位置(左邊優先)
# li = [11, 22, 33, 22, 44]
# v= li.index(22)
# print(v)

# 7. 在指定索引位置插入元素
# li = [11, 22, 33, 22, 44]
# li.insert(0,99)
# print(li)

# 8、 刪除某個值(1.指定索引;2. 默認最后一個),并獲取刪除的值
# li = [11, 22, 33, 22, 44]
# v = li.pop()
# print(li)
# print(v)

# li = [11, 22, 33, 22, 44]
# v = li.pop(1)
# print(li)
# print(v)
# 9. 刪除列表中的指定值,左邊優先
# li = [11, 22, 33, 22, 44]
# li.remove(22)
# print(li)
# PS: pop remove del li[0]    del li[7:9]   clear

# 10 將當前列表進行翻轉
# li = [11, 22, 33, 22, 44]
# li.reverse()
# print(li)

# 11 列表的排序
# li = [11,44, 22, 33, 22]
# li.sort()
# li.sort(reverse=True)
# print(li)
####################################### 深灰魔法 #######################################

# 1.
# 索引取值
print(li[3])

# 2 切片,切片結果也是列表
print(li[3:-1])

# 3 for循環
# while循環
for item in li:
    print(item)
"""
# 列表元素,可以被修改

# li = [1, 12, 9, "age", ["石振文", ["19", 10], "龐麥郎"], "alex", True]

############## 4 索引
# 修改
# li[1] = 120
# print(li)
# li[1] = [11,22,33,44]
# print(li)

# 刪除,第一種方式
# del li[1]
# print(li)
############## 5 切片
# 修改
# li[1:3] = [120,90]
# print(li)
# 刪除
# del li[2:6]
# print(li)

# 6 in 操作
# li = [1, 12, 9, "age", ["石振文", ["19", 10], "龐麥郎"], "alex", True]
# v1 = "石振文" in li
# print(v1)
# v2 = "age" in li
# print(v2)

# 7 轉換
# 字符串轉換列表   li =  list("asdfasdfasdf"), 內部使用for循環
# s = "pouaskdfauspdfiajsdkfj"
# new_li = list(s)
# print(new_li)

# 列表轉換成字符串,
# 需要自己寫for循環一個一個處理: 既有數字又有字符串
# li = [11,22,33,"123","alex"]
# # r = str(li) # '[11,22,33,"123","alex"]'
# # print(r)
# s = ""
# for i in li:
#     s = s + str(i)
# print(s)
# 直接使用字符串join方法:列表中的元素只有字符串
# li = ["123","alex"]
# v = "".join(li)
# print(v)

四、元組

元組,元素不可被修改,不能被增加或者刪除

tu = (11,22,33,44)
tu.count(22),獲取指定元素在元組中出現的次數

tu.index(22)獲取指定元素在元組的索引
# 1. 書寫格式
# tu = (111,"alex",(11,22),[(33,44)],True,33,44,)
# 一般寫元組的時候,推薦在最后加入 ,
# 元素不可被修改,不能被增加或者刪除
# 2. 索引
# v = tu[0]
# print(v)

# 3. 切片
# v = tu[0:2]
# print(v)

# 4. 可以被for循環,可迭代對象
# for item in tu:
#     print(item)

# 5. 轉換
# s = "asdfasdf0"
# li = ["asdf","asdfasdf"]
# tu = ("asdf","asdf")
#
# v = tuple(s)
# print(v)

# v = tuple(li)
# print(v)

# v = list(tu)
# print(v)

# v = "_".join(tu)
# print(v)

# li = ["asdf","asdfasdf"]
# li.extend((11,22,33,))
# print(li)

# 6.元組的一級元素不可修改/刪除/增加
# tu = (111,"alex",(11,22),[(33,44)],True,33,44,)
# # 元組,有序。
# # v = tu[3][0][0]
# # print(v)
# # v=tu[3]
# # print(v)
# tu[3][0] = 567
# print(tu)

五、字典

  • 字典無序

  • 字典的value可以是任何值

  • 布爾值(1,0)、列表、字典不能作為字典的key**

# 1 根據序列,創建字典,并指定統一的值
# v = dict.fromkeys(["k1",123,"999"],123)
# print(v)

# 2 根據Key獲取值,key不存在時,可以指定默認值(None)
# v = dic['k11111']
# print(v)
# v = dic.get('k1',111111)
# print(v)

# 3 刪除并獲取值
# dic = {
#     "k1": 'v1',
#     "k2": 'v2'
# }
# v = dic.pop('k1',90)
# print(dic,v)
# k,v = dic.popitem()
# print(dic,k,v)

# 4 設置值,
# 已存在,不設置,獲取當前key對應的值
# 不存在,設置,獲取當前key對應的值
# dic = {
#     "k1": 'v1',
#     "k2": 'v2'
# }
# v = dic.setdefault('k1111','123')
# print(dic,v)

# 5 更新
# dic = {
#     "k1": 'v1',
#     "k2": 'v2'
# }
# dic.update({'k1': '111111','k3': 123})
# print(dic)
# dic.update(k1=123,k3=345,k5="asdf")
# print(dic)
  • 字典的value可以是任何值

# info = {
#     "k1": 18,
#     "k2": True,
#     "k3": [
#         11,
#         [],
#         (),
#         22,
#         33,
#         {
#             'kk1': 'vv1',
#             'kk2': 'vv2',
#             'kk3': (11,22),
#         }
#     ],
#     "k4": (11,22,33,44)
# }
# print(info)
  • 索引方式找到指定元素

# info = {
#     "k1": 18,
#     2: True,
#     "k3": [
#         11,
#         [],
#         (),
#         22,
#         33,
#         {
#             'kk1': 'vv1',
#             'kk2': 'vv2',
#             'kk3': (11,22),
#         }
#     ],
#     "k4": (11,22,33,44)
# }
# # v = info['k1']
# # print(v)
# # v = info[2]
# # print(v)
# v = info['k3'][5]['kk3'][0]
# print(v)
  • 字典支持 del 刪除

# info = {
#     "k1": 18,
#     2: True,
#     "k3": [
#         11,
#         [],
#         (),
#         22,
#         33,
#         {
#             'kk1': 'vv1',
#             'kk2': 'vv2',
#             'kk3': (11,22),
#         }
#     ],
#     "k4": (11,22,33,44)
# }
# del info['k1']
#
# del info['k3'][5]['kk1']
# print(info)
  • for循環

# dict
# info = {
#     "k1": 18,
#     2: True,
#     "k3": [
#         11,
#         [],
#         (),
#         22,
#         33,
#         {
#             'kk1': 'vv1',
#             'kk2': 'vv2',
#             'kk3': (11,22),
#         }
#     ],
#     "k4": (11,22,33,44)
# }
# for item in info:
#     print(item)
#
# for item in info.keys():
#     print(item)

# for item in info.values():
#     print(item)

# for item in info.keys():
#     print(item,info[item])

# for k,v in info.items():
#     print(k,v)

六、集合

  • set集合,是一個無序且不重復的元素集合

  • 作用:去重,關系運算,

  • 每個元素必須是不可變類型(可hash,可作為字典的key)
    優先掌握的操作:
    1、長度len
    2、成員運算in和not in
    3、|合集
    4、&交集
    5、-差集
    6、^對稱差集
    7、==
    8、父集:>,>=
    9、子集:<,<=

# s={1,2,3,4,5,6}

#添加
# s.add('s')
# s.add('3')
# s.add(3)
# print(s)

#清除
# s.clear()
# print(s)

#拷貝
# s1=s.copy()

s={'sb',1,2,3,4,5,6}
#隨機刪
# s.pop()

#指定刪除
# s.remove('sb')
# s.remove('hellol') #刪除元素不存在會報錯
# s.discard('sbbbb')#刪除元素不存在不會報錯
# print(s)

# python_l=['lcg','szw','zjw','lcg']
# linux_l=['lcg','szw','sb']
# p_s=set(python_l)
# l_s=set(linux_l)
# #求交集
# print(p_s,l_s)
# print(p_s.intersection(l_s))
# print(p_s&l_s)
# #求并集
# print(p_s.union(l_s))
# print(p_s|l_s)
# #差集
# print('差集',p_s-l_s)
# print(p_s.difference(l_s))
# print('差集',l_s-p_s)
# print(l_s.difference(p_s))

#交叉補集
# print('交叉補集',p_s.symmetric_difference(l_s))
# print('交叉補集',p_s^l_s)

python_l=['lcg','szw','zjw','lcg']
linux_l=['lcg','szw','sb']
p_s=set(python_l)
l_s=set(linux_l)
print(p_s,l_s)
# print('差集',p_s-l_s)
# p_s=p_s-l_s
p_s.difference_update(l_s)
print(p_s)

# s1={1,2}
# s2={2,3,5}
# print(s1.isdisjoint(s2)) 如果沒有交集,返回True,否則返回False"""

s1={1,2}
s2={1,2,3}
print(s1.issubset(s2))#s1 是s2 的子集
print(s2.issubset(s1))#False

print(s2.issuperset(s1))#s1 是s2 的父集

s1={1,2}
s2={1,2,3}
# s1.update(s2) #更新多個值

# s1.add(1,2,3,4) #更新一個值
# s1.union(s2) #不更新

print(s1)

七、數據類型總結

  • 數字

  • 字符串

  • 集合:無序,即無序存索引相關信息

  • 元組:有序,需要存索引相關信息,不可變

  • 列表:有序,需要存索引相關信息,可變,需要處理數據的增刪改

  • 字典:無序,需要存key與value映射的相關信息,可變,需要處理數據的增刪改

練習題

1. 實現一個整數加法計算器(如:  5+9  或  5+  9  或  5  +  9 )

n = input('請輸入要計算的加法計算公式:')
v1 = n.strip()
v2 = v1.split('+')
v3 = int(v2[0])
v4 = int(v2[1])
print(v3+v4)

2. 計算用戶輸入的內容中有幾個十進制小數?幾個字母?如:asduiaf878123jkjsfd--‐213928  

n = input("請輸入內容: ")
n1 = 0
n2 = 0
for i in n:
    if i.isalpha() == 1:
        n2 += 1
    if i.isdecimal() == 1:
        n1 += 1
print("數字有 ",n1)
print("字母, ",n2)

3. 制作趣味模板程序,
需求:等待用戶輸入名字、地點、愛好,根據用戶的名字和愛好進行任意實現
如:敬愛可親的 xxx,住在 xxx 地方,愛好是xxx

n = '敬愛可親的{0},住在{1},愛好是{2}'
name = input('請輸入你的名字:')
addr = input('請輸入你的住址:')
likes = input('請輸入你的愛好:')
n1 = n.format(name,addr,likes)
print(n1)
  1. 制作隨機驗證碼,不區分大小寫。
    流程:
        --‐  用戶執行程序
        --‐  給用戶顯示需要輸入的驗證碼
        --‐  用戶輸入的值
            用戶輸入的值和顯示的值相同時現實正確信息;否則繼續生成隨機驗證碼繼續等待用戶輸入

Python有什么基本數據類型

count = 0
while count < 3:
    def check_code():
        import random
        checkcode = ''
        for i in range(4):
            current = random.randrange(0, 4)
            if current != i:
                temp = chr(random.randint(65, 90))
            else:
                temp = random.randint(0, 9)
            checkcode += str(temp)
        return checkcode

    code = check_code()
    print(code)

    n1 = input("請輸入驗證碼:")

    n2 = n1.lower()
    n3 = code.lower()
    if n2 == n3:
        print("驗證通過")
        break
    else:
        print("驗證失敗,請重新輸入")
    count += 1

5. 開發敏感詞語過濾程序,提示用戶輸入內容,如果用戶輸入的內容中包含特殊的字符:如  "打架"  "斗毆",則將內容替換為

li = ['打架','斗毆']
n = input('請輸入你要搜索的內容:')
if n in li:
    print(n.replace(n,'和諧社會'))
else:
    print(n)

6. 制作表格  
    循環提示用戶輸入:用戶名、密碼、郵箱  (要求用戶輸入的長度不超過 20 個字符,如果超過則只有前 20 個字符有效)
    如果用戶輸入  q 或 Q  表示不再繼續輸入,將用戶輸入的內容以表格形式打印

m = '{0}\t{1}\t{2}\n'
s = ""
while True:
    name = input('請輸入用戶名:')
    if name == 'q' or name == 'Q':
        break
    if len(name) > 20:
        name = name[0:20]
    pwd = input('請輸入密碼:')
    if len(pwd) > 20:
        pwd = pwd[0:20]
    mails = input('請輸入郵箱地址')
    if len(mails) > 20:
        mails = mails[0:20]
    n = m.format(name,pwd,mails)
    s = s + n
v = s.expandtabs(30)
print(v)
  1. 有如下值集合 [11,22,33,44,55,66,77,88,99,90...],將所有大于 66 的值保存至字典的第一個key中,將小于 66 的值保存至第二個key的值中。
    即: {'k1': 大于66的所有值, 'k2': 小于66的所有值}

li = [11,22,33,44,55,66,77,88,99,90]
n1 = []
n2 = []
n3 = {}
for i in li:
    if i > 66:
        n1.append(i)
    if i < 66:
        n2.append(i)
# print(n1,n2)

n3.setdefault('k1',n1)
n3.setdefault('k2',n2)

print(n3)

8.乘法表

for i in range(1,10):
    s = ''
    for n in range(1,i+1):
        s += str(n)+' * '+str(i)+' = '+str(n*i)+'\t'
    print(s)

9. 分頁顯示內容

l = []
for i in range(1,302):
    tmpe = ['name'+str(i),'age'+str(i)]
    l.append(tmpe)

while True:
    s = input('請輸入頁碼:')
    if s.isdigit() == 0:
        print('輸入有誤!請輸入十進制數字')
        continue
    s = int(s)
    start = (s - 1) * 10
    end = s * 10
    l1 = l[start:end]
    for i in l1:
        print(i)

以上是“Python有什么基本數據類型”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女