python初学者知识点笔记更新

news2024/12/29 0:21:25

文章目录

  • 1.main函数入口
  • 2.__init__.py 文件作用
  • 3.from .applications import server解释
  • 4.变量没有修饰,直接创建使用
    • 1. 内置数据类型和函数
    • 2. 类和对象
    • 3.总结
  • 5.mod = app.__module__
  • 6.集合对比区分
    • 集合类型:
    • 混合集合类型
  • 7.安装包失败

1.main函数入口

老程序员欢迎加入扣扣组织,783092701

if __name__ == '__main__':

这段代码是Python的程序入口,它会在程序运行时自动执行。在Python中,如果想让一个文件作为程序运行,需要在文件的第一行添加__name__ == '__main__'这行代码。这行代码的作用是让Python知道该文件是否是程序的入口文件,如果是,则执行文件中的代码。

2.init.py 文件作用

init.py 文件是一个特殊文件,它的存在告诉Python解释器这个目录应该被视为一个Python包(package)。这个文件可以是空的,但它必须存在(在Python 3.3及以后的版本中,对于纯Python包来说,init.py 文件不再是必需的,但如果你希望包在旧版本的Python中也能工作,或者你的包包含了一些需要在包被导入时执行的初始化代码,那么仍然需要这个文件)。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在__init__函数中,可以定义该类的属性和成员变量,并对它们进行初始化。例如:

class Person:
    def __init__(self, name, age):
        self.name = name
        self.age = age

这段代码是Python类的构造函数,它用于初始化类的对象。

3.from .applications import server解释

从当前包(即包含这个导入语句的文件的包)中导入名为 applications 的子包或模块,并从这个子包或模块中进一步导入名为 server 的内容

对比 from fastapi import FastAPI
从fastapi这个包中导入FastAPI类

4.变量没有修饰,直接创建使用

函数式编程,有些东西都不知道哪里来的就用起来了
直接创建变量使用,这个名可以不叫response
在这里插入图片描述
分析,response = await call_next(request) 这行代码之所以不需要对 response 进行额外的修饰(比如使用 async 关键字),是因为 await 已经处理了异步调用的等待和结果接收。这里的 response 变量简单地用于存储 await call_next(request) 执行完成后的结果,这个结果通常是下一个中间件或路由处理函数返回的响应对象。

1. 内置数据类型和函数

对于Python的内置数据类型(如整数、浮点数、字符串、列表、元组、字典、集合等)和内置函数,你通常不需要显式地定义对象来使用它们。这些类型和函数已经存在于Python的内置命名空间中,你可以直接使用它们。

# 使用内置数据类型  
num = 10  # 整数  
text = "Hello, World!"  # 字符串  
lst = [1, 2, 3]  # 列表  
  
# 使用内置函数  
result = len(lst)  # 调用内置函数len来获取列表的长度

2. 类和对象

当你使用Python的类(class)来定义自己的数据结构或行为时,你需要创建(或“实例化”)类的对象来使用它。这是因为类是用于创建对象的蓝图或模板,而对象则是根据这个蓝图创建的具体实例。

class MyClass:  
    def __init__(self, name):  
        self.name = name  
  
    def greet(self):  
        print(f"Hello, {self.name}!")  
  
# 实例化MyClass类  
my_object = MyClass("Alice")  
  
# 使用对象的方法  
my_object.greet()  # 输出: Hello, Alice!

在这个例子中,MyClass 是一个类定义,它包含了一个构造函数 init 和一个方法 greet。要使用这个类,我们首先必须实例化它,创建一个对象 my_object,然后我们可以通过这个对象来调用 greet 方法。

3.总结

虽然Python是一种面向对象的语言,但它也支持函数式编程。在函数式编程中,你更倾向于使用函数而不是对象,但这并不意味着你不需要定义函数就可以直接使用它(因为你还是需要知道函数名才能调用它)。

5.mod = app.module

解释:

  • 它执行了一个特定的操作来获取与app对象相关联的模块(module)的名称。这里,app可以是一个类、函数、变量或者任何定义在某个模块中的对象。__module__是一个特殊的属性,它存在于几乎所有的Python对象中(除了内建类型和一些特殊情况),用于指示该对象是在哪个模块中定义的。
  • app.__module__返回的是一个字符串,表示app对象所在模块的名称。这个名称通常包括模块的文件名和(如果模块是包的一部分)其包的路径。

举例

  • 如果app是在名为myapp.py的文件中定义的,并且该文件位于Python的搜索路径中的某个目录下,那么app.__module__的值可能就是’myapp’(如果myapp.py位于顶层目录)或者是一个更长的路径,比如’mypackage.subpackage.myapp’(如果myapp.py是mypackage.subpackage包的一部分)。

使用场景

  • 这个特性在动态编程、调试、日志记录或任何需要知道对象来源模块的场景中都非常有用。例如,你可能想要记录一个函数或方法被调用的模块,以便更好地理解程序的执行流程或调试问题。

注意bug:
需要注意的是,对于内建类型(如int、list等)和一些特殊情况(如使用exec或eval动态创建的对象),__module__属性可能不存在或返回的值可能不是你期望的。在这些情况下,尝试访问__module__属性可能会引发AttributeError异常。

6.集合对比区分

集合类型:

列表(List),集合(Set),元组(Tuple),字典(Dictionary)

  • 有序:列表(List),元组(Tuple)
  • 不可重复:集合(Set)
  • key-value:字典(Dictionary),元组列表
  • 不可更改:元组(Tuple)
  • 大小中括号:
    {}:集合(Set),字典(Dictionary)
    []:列表(List)
    ():元组(Tuple)

混合集合类型

元组列表,元组嵌套,深嵌套,字典列表等等

print("===============定义元组,遍历输出===============")
# 元组是一种有序且不可更改的集合
fruits = ('apple', 'banana', 'cherry')
for fruit in fruits:
    print(fruit)

print("===============定义字典,遍历输出===============")
# 字典一个无序的、可变的、有索引的集合
student_info = {
    'Tom': 95,
    'Jerry': 90,
    'Mary': 85,
    'Bob': 98}
for name, score in student_info.items():
    print(f"{name}: {score}")

print("===============定义列表,遍历输出================")
# 定义一个列表 一种有序且可更改的集合
students = ['Alice', 'Bob', 'Charlie']
for student in students:
    print(student)

print("===============定义set可变集合,遍历输出================")
# set集合,无序且不包含重复元素的集合
my_set = set()

# 添加元素到集合
my_set.add(1)
my_set.add(2)
my_set.add(3)

# 遍历输出集合中的元素
for item in my_set:
    print(item)
print("=====定义集合,遍历输出====")
# 定义一个集合,元素为字符串
names = {'Alice', 'Bob', 'Bob', 'Charlie'}

# 使用 for 循环遍历集合中的元素
for name in names:
    print(name)

# 创建一个不可变集合
fruits = frozenset(['apple', 'banana', 'cherry'])

# 使用 for 循环遍历集合中的元素
for fruit in fruits:
    print(fruit)

print("===============混合类型================")
print("===============定义元组列表,遍历输出================")
# 元组列表
names = [('John', 25), ('Alice', 30), ('Bob', 35)]

for _, member in names:
    print(f"Member: {member}")

# 遍历元组 set 集合
# 1. 创建一个元组 set 集合
student_scores = {'Alice': 95, 'Bob': 92, 'Charlie': 97}
# 2. 使用 for 循环遍历该集合
for student, score in student_scores.items():
    print(f'{student}: {score}')

# 遍历元组字典
# 首先定义一个元组字典
student_info = (
    ('Alice', 'Math', 95),
    ('Bob', 'English', 90),
    ('Charlie', 'Physics', 98)
)

# 遍历元组字典
for student in student_info:
    # 提取学生姓名、课程名称和成绩
    name, course, score = student
    # 打印学生信息
    print(f'Student name: {name}')
    print(f'Course: {course}')
    print(f'Score: {score}')
    print()

# 创建一个嵌套元组的例子
nested_tuple = (1, 2, (3, 4, 5), 6)

# 访问嵌套元组中的元素
print(nested_tuple)  # 输出: (1, 2, (3, 4, 5), 6)
print(nested_tuple[2])  # 输出: (3, 4, 5),这是嵌套元组
print(nested_tuple[2][1])  # 输出: 4,这是嵌套元组中的第二个元素

# 嵌套可以非常深
deep_nested_tuple = (1, (2, (3, (4, (5, 6)))), 7)
print(deep_nested_tuple)  # 输出: (1, (2, (3, (4, (5, 6)))), 7)
print(deep_nested_tuple[1][1])

print(deep_nested_tuple[1][1][1])
print(deep_nested_tuple[1][1][1][1])
# 大模型给出的错误答案
# print(deep_nested_tuple[1][1][2][1][0])

multi_nested_tuple = (1, (2, (3, (4, 5))))
print(multi_nested_tuple[1][1][1][0])


# 字典列表
# 实现一个字典列表,列表中每个元素是一个字典
# 字典的键是字符串,值可以是任意类型
# 实现函数:
# 创建一个空的字典列表
def create_dict_list():
    return []


# 添加一个元素到字典列表中
# 参数:
# dict_list - 字典列表
# key - 字典的键
# value - 字典的值
def add_element_to_dict_list(dict_list, key, value):
    dict_list.append({key: value})


# 返回字典列表的长度
# 参数:
# dict_list - 字典列表
def get_dict_list_length(dict_list):
    return len(dict_list)


# 返回第 index 个元素
# 参数:
# dict_list - 字典列表
# index - 元素的索引,从 0 开始计算
def get_element_from_dict_list(dict_list, index):
    return dict_list[index]


# 修改第 index 个元素
# 参数:
# dict_list - 字典列表
# index - 元素的索引,从 0 开始计算
# key - 字典的键
# value - 字典的值
def modify_element_in_dict_list(dict_list, index, key, value):
    dict_list[index][key] = value


# 删除第 index 个元素
# 参数:
# dict_list - 字典列表
# index - 元素的索引,从 0 开始计算
def delete_element_from_dict_list(dict_list, index):
    del dict_list[index]


# 判断字典列表中是否包含某个元素
# 参数:
# dict_list - 字典列表
# key - 字典的键
def contains_element_in_dict_list(dict_list, key):
    for element in dict_list:
        if key in element:
            return True
    return False


# 遍历字典列表
# 参数:
# dict_list - 字典列表
# 遍历函数的形式为:def visit_element(element):
def traverse_dict_list(dict_list, visit_element):
    for element in dict_list:
        visit_element(element)


# 示例:
dict_list = create_dict_list()
add_element_to_dict_list(dict_list, "name", "alice")
add_element_to_dict_list(dict_list, "age", 20)
print("长度:", get_dict_list_length(dict_list))
print("第 0 个元素:", get_element_from_dict_list(dict_list, 0))
modify_element_in_dict_list(dict_list, 0, "name", "alice2")
delete_element_from_dict_list(dict_list, 1)
print("长度:", get_dict_list_length(dict_list))
print("是否包含 name:", contains_element_in_dict_list(dict_list, "name"))
traverse_dict_list(dict_list, lambda x: print(x))


7.安装包失败

在这里插入图片描述

报错:
Try to run this command from the system terminal. Make sure that you use the correct version of ‘pip’ installed for your Python interpreter located at ‘F:\python-workspaces\TestEnv\venv\Scripts\python.exe’.

问题原因:

解决办法:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1927719.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用react和chainlit开发大模型结果人工评测平台

项目背景 利用LLM的prompt做了个简单的服务推荐助手,依据用户的提问找出合适的服务项目推荐给的用户。为了测评prompt的效果,使用reactchainlit开发了一个简单的效果测评平台。在该平台上,可以模拟用户向LLM发出问题,并对大模型返…

阿里通义音频生成大模型 FunAudioLLM 开源

简介 近年来,人工智能(AI)技术的进步极大地改变了人类与机器的互动方式,特别是在语音处理领域。阿里巴巴通义实验室最近开源了一个名为FunAudioLLM的语音大模型项目,旨在促进人类与大型语言模型(LLMs&…

【过题笔记】 7.15

Array Without Local Maximums 算法:动态规划 简要思路: 考虑左边的数跟当前位置的关系,不难想到只有三种情况:大于,小于,等于。 于是可以得到状态 f [ i ] [ j ] [ 0 / 1 / 2 ] f[i][j][0/1/2] f[i][j][…

数据库的管理

目录 远程连接的方式 修改数据库uuid流程 数据库的概念 关系型数据库 非关系型数据库 关系型数据和非关系型数据库优缺点 mysql的数据类型 数据库的管理 sql中的名词 sql语言的分类 1.DDL:创建库和表的语句 create 2.DML: 插入数据 insert 修改和更…

内存函数(C语言)

内存函数 以下函数的头文件:string.h 针对内存块进行处理的函数 memcpy 函数原型: void* memcpy(void* destination, const void* source, size_t num);目标空间地址 源空间地址num,被拷贝的字节个数 返回目标空间的起始地…

STM32智能医疗监测系统教程

目录 引言环境准备智能医疗监测系统基础代码实现:实现智能医疗监测系统 4.1 数据采集模块 4.2 数据处理与控制模块 4.3 通信与网络系统实现 4.4 用户界面与数据可视化应用场景:医疗监测与管理问题解决方案与优化收尾与总结 1. 引言 智能医疗监测系统通…

RocketMQ源码学习笔记:Producer发送消息流程

这是本人学习的总结,主要学习资料如下 马士兵教育rocketMq官方文档 目录 1、Overview2、验证消息3、查找路由4、选择消息发送队列4.1、选择队列的策略4.2、源码阅读4.2.1、轮询规避4.2.2、故障延迟规避4.2.2.1、计算规避时间4.2.2.2、选择队列 4.2.3、ThreadLocal的…

正运动控制器:EtherCAT总线初始化

1、EtherCAT总线初始化的目的 运动控制器的EtherCAT 总线接口可用于连接 EtherCAT 伺服驱动器和 EtherCAT 扩展模块,无论连接什么模块, EtherCAT 总线都需要编写一段 EtherCAT 总线初始化程序来进行电机和 EtherCAT 扩展模块的使能。使能之后的应用与脉…

QT多线程下,信号槽分别在什么线程中执行,如何控制?

可以通过connect的第五个参数进行控制信号槽执行时所在的线程 connect有几种连接方式,直接连接、队列连接和 自动连接 直接连接(Qt::DirectConnection):信号槽在信号发出者所在的线程中执行 队列连接(Qt::QueuedConn…

LeetCode-返回链表倒数第K个节点、链表的回文结构,相交链表

一、返回链表倒数第k个节点 . - 力扣(LeetCode) 本体思路参展寻找中间节点的方法,寻找中间节点是定义快慢指针,快指针每次走两步,慢指针每次走一步,当快指针为空或者快指针的下一个节点是空时,…

vue实现提交时对不同板块的表单内容进行校验

需求 1、需要对第一个红色框框板块内所有带星号的地方进行校验,并将提示语显示到对应的输入框下面,如图: 2、第二个红色框框板块中,点击 “添加相关人员” 能实现对多人的添加功能,并且能绑定相对应的校验规则 3、在…

linux进行redis的安装并使用RDB进行数据迁移

现在有两台电脑,分别是A,B,现在我要把A电脑上的redis的数据迁移到B电脑上,B电脑上是没有安装redis的 1.找到A电脑的redis的版本 1.先启动A电脑的redis,一般来说,都是直接在linux的控制台输入:re…

数据结构与算法(1):递归函数的设计技巧

1.前言 哈喽小伙伴们大家好哦~从今天开始笔者就要开始正式学习数据结构与算法了,在这里写知识博客既是做一些学习笔记,又相当于给大家做知识分享咯,希望大家一起加油哦! 2.正文 2.1递归的引入 在正式讲解递归之前,…

创建鸿蒙手机模拟器(HarmonyOS Emulator)

文 | Promise Sun 一.前提条件: 鸿蒙项目开发需要使用模拟器进行开发测试,但目前想在DevEco Studio开发工具中使用模拟器就必须到华为官网进行报名申请,参加“鸿蒙模拟器(HarmonyOS Emulator)Beta活动申请”。 申请审…

中间件的理解

内容来源于学习网站整理。【一看就会】什么是前端开发的中间件?_哔哩哔哩_bilibili 每日八股文~白话说mq,消息中间件_哔哩哔哩_bilibili 例如: 1)两个人打电话,中间的通信网络就是中间件。 2)菜鸟驿站&…

SpringBoot以及swagger的基本使用

1、SpringBoot是什么? 一种快速开发、启动Spring的框架、脚手架 遵循“约定优于配置”的思想,使得能够快速创建和配置Spring应用 2、SpringBoot的核心特性 自动配置,一些依赖、默认配置都预设好了,减少了配置量起步依赖&#x…

ROS2-Navigation2初体验:Gazebo“打不开”

输入ros2 launch nav2_bringup tb3_simulation_launch.py headless:False后只能打开RVIZ而无法打开Gazebo的问题,多次尝试解决后发现只是多等待一会儿即可,在此给同样学习Navigation2的朋友们提个醒 。 Getting Started — Nav2 1.0.0 documentation 1…

Mindspore框架CycleGAN模型实现图像风格迁移|(二)实例数据集(苹果2橘子)

Mindspore框架:CycleGAN模型实现图像风格迁移算法 Mindspore框架CycleGAN模型实现图像风格迁移|(一)CycleGAN神经网络模型构建Mindspore框架CycleGAN模型实现图像风格迁移|(二)实例数据集(苹果2橘子&#…

补充性文件

第一 二章 1,关系型数据库是什么?其中的关系是指什么? 答: 关系型数据库是一些相关的表和其他数据库对象的集合。数据模型符合满足一定条件的二维表格式。 2,E-R模型? 实体为表。用矩形表示。属性为字…

嵌入式物联网在工业中的应用——案例分析

作者主页: 知孤云出岫 目录 嵌入式物联网在工业中的应用——案例分析引言1. 智能工厂1.1 实时监控与数据采集 2. 智能物流2.1 库存管理 3. 智能维护3.1 设备故障预测 4. 智能交通4.1 交通流量监测 总结 嵌入式物联网在工业中的应用——案例分析 引言 嵌入式物联网(…