八大基本数据类型

八大基本数据类型

【一】八大基本数据类型介绍

# 【1】数字类型
# 	(1)整数类型
# 	(2)浮点数类型
# 【2】字符串类型
# 【3】列表类型
# 【4】字典类型
# 【5】布尔类型
# 【6】元组类型
# 【7】集合类型

【二】数字类型

整数类型
# 语法: 变量名 = 数字
age = 18
# 使用场景 加减乘除
浮点数类型
# 语法: 变量名 = 浮点数
weight = 50.00
#使用场景 
身高  取款  体重 等等

【三】字符串类型 " "

1】用途
# 用来标识文本信息2】语法
# 变量名 = 变量值(加引号 ,一个单引号,一个双引号,三个单引号,三个双引号)
name = "dream"
name = 'Dream'
name = '''Dream'''
name = """Dream"""
#单双引号混用
name = "'name'"  # 双引号中混用的单引号
print(name, type(name))  # 'name' <class 'str'>
name = '"name"'  # 单引号中混用的双引号
print(name, type(name))  # "name" <class 'str'>
# 测试在双引号内存出现单独的单引号
name = "name'"
print(name, type(name))  # name' <class 'str'>
name = 'name"'
print(name, type(name))  # name" <class 'str'>

#防止歧义
单引号内部不能出现单独单引号,但是单引号内部可以出现单独的双引号
双引号内部不能出现单独双引号,但是双引号内部可以出现单独的单引号

在三引号内部,如果第一行不写内容默认存在一个换行
sentence = '''my name is dream ,
I'm 18 years old,
hope you 'wonderful!'
'''
print(sentence, type(sentence))  # <class 'str'>3】使用方法
# (1)字符串加法
print(1 + 1)
# 字符串 + 字符串 =  字符串
print("1" + "1", type("1" + "1"))  # 11 <class 'str'>

# (2)字符串乘法
print(1 * 9)
# 字符串 * 数字 = 当前字符串重复出现几次
print("1" * 9)

索引取值

word = "Hello World"
# 索引取值的语法 字符串[索引坐标]
# 取出来的值还是字符串
print(word[0])
print(word[5], type(word[5]))  # <class 'str'>
print(word[10])

计算当前字符串的总字符数

print(len(word), type(len(word)))  # 11
# 当我们使用正索引取值的时候,索引是从 0 开始 0 - 10
print(word[len(word) - 1])
# 如果是负索引取值,从 -1 开始 ,可以取到 -11
print(word[-len(word)])

字符串的格式化输出

# myself_sentence = "my name is dream,my age is 18,"
# myself_sentence = "my name is hope,my age is 18,"
# 变量可以用来存储值

【1】%占位输出法

# myself_sentence = "my name is %s,my age is %s" % (name, age)
# myself_sentence = "my age is %s,my name is %s" % (name, age)
%s : string字符串类型的数据
%d : int类型的数据
# myself_sentence = "my age is %d,my name is %s" % (name, age)
# TypeError: %d format: a real number is required, not str

【2】f + {}

# myself_sentence = f"my name is {name},my age is {age}"

【3】format输出语法

# 按照位置传值
# myself_sentence = "my name is {},my age is {}".format(name, age)
# 按照关键字传值
myself_sentence = "my age is {age},my name is {name}".format(name=name, age=age)
print(myself_sentence)

# \ 在python中输入数转移符号
# name = "dream \n"
name = "dream\\"  # dream\
print(name)
print(age)

【四】列表类型 [ ]

# 【1】作用
# 可以在列表中存放从多个值,不限制数据类型
# 比如我用一个列表存储很多学生的名字
# 【2】语法
name_list = ["dream", "hope"]
print(name_list, type(name_list))
# ['dream', 'hope'] <class 'list'>
# 【3】放了值是为了方便使用
# (1)索引取值
# 索引取值正向从 0 开始,负向 -1 开始
print(name_list[0])
print(name_list[-1])

# 【4】索引支持嵌套
info_list = [
    "dream", ["15", ["上海"]]
]
# 如果想取到最后一层
print(info_list)  # ['dream', ['15', ['上海']]]
print(info_list[1])  # ['15', ['上海']]
print(info_list[1][1])  # ['上海']
print(info_list[1][1][0])  # 上海

【五】字典类型

# 【1】作用
# 可以记录多个值,并且这些值带有各自及的名字
# 字典数据存储的方式 是  key:value

# 【2】语法
# 里面存的每一个值都是 key:value 的 kv键值对
infO_data = {
    "name": "dream",
    "age": 18,
    "hobby": ["music", "run", "make girlfriends"]
}

字典不支持索引取值

# print(infO_data[0])

字典根据键取值

print(infO_data["name"])  # dream
# [key] 取值,如果字典中不存在当前 键 就会报错
# print(infO_data["addr"])# KeyError: 'addr'

.get(键)取值

print(infO_data.get("name"))  # dream
# .get(key) 取值,如果字典中不存在键对应的值不会报错,而是反悔了一个 None
print(infO_data.get("addr"), type(infO_data.get("addr")))  # None <class 'NoneType'>

示例

info = {
    'name': 'Dream',
    'addr': {
        '国家': '中国',
        'info': [
            666,
            {'age': 18}, 
            999,
            {'编号': 466722, 'hobby': ['read', 'study', 'music']}
        ]
    }
}

# 格式化输出
# sentence = "my name is name ,my age is age ,my id is id ,my location is location , my hobby is music-read-study"
# 从 info 字典中获取 name 键对应的值即可
name = info.get("name")
# 从 info 字典中 获取到 addr 对应的 字典 ,再 从字典中获取 键 国家 对应的值
location = info["addr"].get("国家")
age = info["addr"]["info"][1].get("age")
id = info["addr"]["info"][3].get("编号")
hobby = info["addr"]["info"][-1].get("hobby")[0] + '-' + info["addr"]["info"][-1].get("hobby")[1] + '-' + \
        info["addr"]["info"][-1].get("hobby")[2]

# sentence = f"""my name is {name} ,
# my age is {age} ,
# my id is {id} ,
# my location is {location} ,
# my hobby is {hobby}
# """

sentence = f"""my name is {info.get("name")} ,
my age is {info["addr"]["info"][1].get("age")} ,
my id is {info["addr"]["info"][3].get("编号")} ,
my location is {info["addr"].get("国家")} , 
my hobby is {info["addr"]["info"][-1].get("hobby")[0] + '-' + info["addr"]["info"][-1].get("hobby")[1] + '-' + info["addr"]["info"][-1].get("hobby")[2]}
"""
print(sentence)

【六】布尔类型 True False

布尔类型即真或假

在python中真假情况:

# 哪些情况是真?
# 数字 1 为真
# 哪些情况是假?
# 不存在的情况:空值为假,空的字符串、空的列表、空的字典、空的元组、数字 0
name = ""
name = []
name = {}
name = 2
# name = False
print(bool(name))  # False
name = "11"
print(bool(name))

【七】元组类型 ( )

元组用来存储不变的元素

特别注意:元组中有一个元素的时候一定要加 ,

name = ("dream")
print(name, type(name))  # dream <class 'str'>
name = ("dream",)
print(name, type(name))  # ('dream',) <class 'tuple'>
# name[0] = "hope"
# print(name)

# 元组的解包 ; 解压赋值
info = ("dream", 18)
print(info[0])
print(info[1])
name, age = ("dream", 18)
print(name)
print(age)

【八】集合类型

集合无序且去重

{key:value} : 字典

{key} : 集合

num = {1, 2, 3, 4, 5, 5, 5, 5, 5, 5}
print(num, type(num))

num = {1, 2, 3, 'name', 'dream', 4, 1.11, 5, 5, 5, 5, 5, 5}
print(num)
# {1, 2, 3, 4, 1.11, 5, 'dream', 'name'}
# {1, 'name', 3, 2, 4, 1.11, 5, 'dream'}
# {'name', 2, 3, 4, 1, 1.11, 5, 'dream'}
无序 去重

集合类型中不能存放字典和列表 :

*** 因字典和列表是可变数据类型不能被 hash***

posted @   随机昵称yi  阅读(113)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示