Python语言基础与应用:掌握自动计算和控制流程基础

发布时间: 2024-01-26 19:28:06 阅读量: 37 订阅数: 43
# 1. Python语言基础介绍 ## 1.1 Python的历史和特点 Python是一种高级、解释型的编程语言,由Guido van Rossum在上世纪90年代初开发出来。Python在开发过程中注重代码的可读性和简洁性,强调代码的易读性,因此被称为"优雅"的编程语言。 Python具有以下特点: - 简洁易读:Python具有清晰简洁的语法结构,易于理解和学习。它使用缩进来表示代码块,而不是使用大括号,使得代码更加整洁。 - 跨平台:Python可以在多个操作系统上运行,包括Windows、Linux和Mac OS等。 - 强大的开源生态系统:Python拥有丰富的第三方库和工具,它们可以满足各种应用需求,如数据分析、Web开发、人工智能等。 - 面向对象:Python支持面向对象编程,可以创建类和对象,实现代码的模块化和复用。 - 动态类型:Python是一种动态类型语言,不需要指定变量类型,可以根据赋值自动推断变量类型。 - 快速开发:Python的语法简洁,提供了许多高级特性和标准库,能够极大地提高开发效率。 ## 1.2 Python的安装和开发环境设置 在开始学习Python之前,需要先安装Python解释器和配置开发环境。以下是安装Python的步骤: 1. 在Python官网(https://www.python.org)下载最新的Python安装包。 2. 运行安装包,并按照提示进行安装。 3. 在安装过程中,记得选择要安装的组件,例如Python解释器和pip包管理工具。 4. 安装完成后,可以在命令行中输入`python --version`来验证Python是否正确安装。 除了Python解释器,还可以选择使用集成开发环境(IDE)来编写和运行Python代码。一些常用的Python开发环境包括PyCharm、Anaconda、Jupyter Notebook等。 ## 1.3 第一个Python程序 下面我们来编写第一个Python程序,打印"Hello, Python!"。 ```python # 这是一个注释,用于说明代码的作用 print("Hello, Python!") ``` 代码解析: - `print()`是Python内置的一个函数,用于将括号中的内容输出到控制台。 - "Hello, Python!"是一个字符串,用双引号括起来表示。 在Python中,注释可以使用`#`符号开始,并且可以放在代码的任何地方,用于解释代码的功能和目的。 运行这段代码,将会在控制台上输出"Hello, Python!",表示代码执行成功。 这是一个简单的例子,但它展示了Python的基本语法和程序执行过程。在后续的章节中,我们将介绍更多的语法和代码示例。 # 2. 数据类型和变量 在Python中,可以使用不同的数据类型来表示不同的数据结构和值。本章将介绍Python中常用的数据类型及其操作。 ### 2.1 基本数据类型 #### 2.1.1 整型(int) 整型是Python中表示整数的数据类型。可以进行基本的数学运算,如加法、减法、乘法和除法。 ```python # 整型变量的定义和使用 num1 = 10 num2 = 5 sum = num1 + num2 print("两数之和为:", sum) # 输出:两数之和为:15 ``` #### 2.1.2 浮点型(float) 浮点型是Python中表示实数的数据类型。与整型一样,可以进行数学运算,但要注意浮点数的精度问题。 ```python # 浮点型变量的定义和使用 num1 = 3.1415 num2 = 2.7182 product = num1 * num2 print("两数之积为:", product) # 输出:两数之积为:8.5391573 ``` #### 2.1.3 字符串(str) 字符串是Python中表示文本的数据类型,用单引号或双引号括起来。可以进行字符串的拼接、索引和切片等操作。 ```python # 字符串的定义和使用 str1 = "Hello" str2 = "World" greeting = str1 + " " + str2 print(greeting) # 输出:Hello World # 字符串的索引和切片 word = "Python" print(word[0]) # 输出:P print(word[1:4]) # 输出:yth ``` ### 2.2 变量的定义和使用 在Python中,可以使用变量来存储和操作数据。变量名可以由字母、数字和下划线组成,但不能以数字开头。 ```python # 变量的定义和使用 age = 25 name = "Alice" print("My name is", name, "and I'm", age, "years old.") # 输出:My name is Alice and I'm 25 years old. ``` ### 2.3 常用的数据结构 Python提供了一些常用的数据结构,包括列表、元组和字典。 #### 2.3.1 列表(list) 列表是一种有序的数据集合,可以包含不同类型的元素。可以进行元素的增加、删除、修改和查找操作。 ```python # 列表的定义和使用 fruits = ["apple", "banana", "orange"] fruits.append("grape") # 添加元素 print(fruits) # 输出:['apple', 'banana', 'orange', 'grape'] fruits.remove("banana") # 删除元素 print(fruits) # 输出:['apple', 'orange', 'grape'] fruits[0] = "watermelon" # 修改元素 print(fruits) # 输出:['watermelon', 'orange', 'grape'] print(fruits[1]) # 输出:orange ``` #### 2.3.2 元组(tuple) 元组与列表类似,但元素不可修改。可以用于存储多个值,并可以进行元素的访问和切片操作。 ```python # 元组的定义和使用 point = (3, 4) print(point[0]) # 输出:3 x, y = point # 元组的解包 print("x =", x) # 输出:x = 3 print("y =", y) # 输出:y = 4 ``` #### 2.3.3 字典(dict) 字典是一种键值对的数据结构,用于存储无序的数据集合。可以通过键来访问、修改和删除对应的值。 ```python # 字典的定义和使用 person = { "name": "Alice", "age": 25, "city": "New York" } print(person["name"]) # 输出:Alice person["age"] = 26 # 修改键对应的值 print(person) # 输出:{'name': 'Alice', 'age': 26, 'city': 'New York'} del person["city"] # 删除键及对应的值 print(person) # 输出:{'name': 'Alice', 'age': 26} ``` 本章介绍了Python中常用的数据类型和变量的定义和使用方法,以及常用的数据结构。在下一章节中,将介绍控制流程的基础知识。 # 3. 控制流程基础 控制流程是编程中非常重要的一部分,通过控制流程可以实现程序的逻辑控制和流程控制。在Python中,控制流程主要包括条件语句和循环语句,以及相应的控制语句。 #### 3.1 条件语句:if-else语句的使用 条件语句是根据条件表达式的真假来执行相应的代码块。在Python中,条件语句使用if、elif(else if)、else关键字来实现。 ```python # 示例:使用if-else语句判断成绩等级 score = 85 if score >= 90: print("优秀") elif score >= 80: print("良好") elif score >= 60: print("及格") else: print("不及格") ``` 上述代码中,根据成绩不同的范围,输出不同的等级。在Python的条件语句中,需要注意代码块的缩进,Python使用缩进来表示代码块,因此缩进的正确使用非常重要。 #### 3.2 循环语句:for和while循环的应用 循环语句可以重复执行特定的代码块,Python提供了for循环和while循环两种方式。 ##### 3.2.1 for循环 for循环可以遍历可迭代对象(如列表、元组、字典等),执行对应的代码块。 ```python # 示例:使用for循环遍历列表 fruits = ["apple", "banana", "cherry"] for fruit in fruits: print(fruit) ``` 上述代码中,for循环遍历了列表fruits,并打印出每个水果的名称。 ##### 3.2.2 while循环 while循环会在条件表达式为真的情况下一直执行相应的代码块,直到条件表达式为假时循环停止。 ```python # 示例:使用while循环计算1到100的和 sum = 0 i = 1 while i <= 100: sum += i i += 1 print("1到100的和为:", sum) ``` 上述代码中,使用while循环计算了1到100的累加和。 #### 3.3 循环控制:break和continue的作用 在循环中,可以使用break语句提前终止循环,也可以使用continue语句跳过当前循环执行下一次循环。 ```python # 示例:使用break和continue控制循环 for i in range(1, 11): if i == 5: break # 当i等于5时,终止循环 if i % 2 == 0: continue # 当i为偶数时,跳过当前循环,执行下一次循环 print(i) ``` 上述代码中,通过break和continue语句控制了循环的执行流程。 # 4. 函数和模块 函数和模块是Python编程中非常重要的部分,它们可以帮助我们组织代码、提高代码复用性和可维护性。在本章节中,我们将深入介绍函数的定义和调用、函数参数和返回值,以及模块的导入和使用。 #### 4.1 函数的定义和调用 在Python中,函数通过关键字`def`来定义,通过函数名和参数列表来调用。下面是一个简单的函数示例: ```python def greet(name): print(f"Hello, {name}!") greet("Alice") ``` 代码解释: - 使用关键字`def`定义了一个名为`greet`的函数,它接受一个参数`name`。 - 在函数内部使用`print`函数输出了一条问候语,其中包含传入的参数`name`。 - 调用`greet`函数并传入参数`"Alice"`,输出了"Hello, Alice!"。 #### 4.2 函数参数和返回值 Python函数可以接受位置参数、默认参数、可变参数和关键字参数,并且可以返回一个或多个数值。下面是一个函数参数和返回值的示例: ```python def power(base, exponent=2): result = base ** exponent return result print(power(3)) # 输出 9,使用默认的指数值 print(power(2, 3)) # 输出 8,指定了指数值为3 ``` 代码解释: - 函数`power`接受两个参数,其中`exponent`有默认值2。 - 在函数内部,计算了`base`的`exponent`次方并将结果返回。 - 分别调用`power`函数,输出了不同的计算结果。 #### 4.3 模块的导入和使用 在Python中,我们可以把函数、变量等保存在一个.py文件中,这个文件被称为模块。我们可以使用`import`关键字导入模块,并使用其中定义的函数和变量。下面是一个简单的模块导入示例: ```python import math print(math.sqrt(16)) # 输出 4.0,使用math模块中的平方根函数 ``` 代码解释: - 使用`import`关键字导入Python标准库中的`math`模块。 - 调用`math.sqrt`函数计算16的平方根,并输出结果。 以上是函数和模块的基本使用,通过合理的定义函数和模块的导入,我们可以更好地组织代码并提高代码的复用性。 # 5. 文件操作和异常处理 文件操作和异常处理是Python编程中非常重要的部分,本章将重点介绍文件读写操作和异常处理的相关知识。 #### 5.1 文件读写操作 在Python中,可以使用内置的open()函数来打开一个文件,并通过文件对象进行读写操作。下面是一个简单的文件读操作示例: ```python # 打开文件 file = open('example.txt', 'r') # 读取文件内容 content = file.read() print(content) # 关闭文件 file.close() ``` 在这个示例中,我们首先打开了一个名为`example.txt`的文件,使用'r'模式表示只读。然后通过`read()`方法读取文件的内容,并最后关闭文件。 #### 5.2 文件打开和关闭 为了保证文件操作的安全性和可靠性,对文件的打开和关闭是非常重要的。Python提供了`with`语句来自动关闭文件,如下所示: ```python with open('example.txt', 'w') as file: file.write('Hello, world!') ``` 在这个例子中,我们使用`with`语句来打开`example.txt`文件,并以写入模式('w')写入了一行内容。在`with`语句的结束时,文件会自动关闭,无需手动调用`close()`方法。 #### 5.3 异常处理:try-except语句的应用 在Python中,可以使用`try-except`语句来捕获和处理异常。下面是一个简单的异常处理示例: ```python try: num = int(input("请输入一个数字:")) print("输入的数字是:", num) except ValueError: print("输入的不是有效的数字,请重新输入") ``` 在这个例子中,如果用户输入的不是有效的数字,`int()`函数会抛出`ValueError`异常,我们使用`try-except`语句来捕获这个异常,并输出提示信息。 文件操作和异常处理是Python编程中的重要环节,合理的文件操作和异常处理可以提高程序的健壮性和可靠性。 # 6. 自动计算和应用案例 在本章中,将介绍如何使用Python进行自动计算,并给出一些应用案例。 ### 6.1 使用Python进行数学运算 Python作为一种高级编程语言,具有广泛的数学计算功能。我们可以使用Python内置的数学库进行各种数学运算,例如求平方根、对数、三角函数等。 下面是一个使用Python进行简单数学运算的示例代码: ```python import math # 求平方根 x = 16 sqrt = math.sqrt(x) print("The square root of", x, "is", sqrt) # 求自然对数 y = 10 log = math.log(y) print("The natural logarithm of", y, "is", log) # 求正弦值 angle = 45 sin = math.sin(math.radians(angle)) print("The sine of", angle, "degrees is", sin) ``` 代码解释: 首先,我们导入了Python内置的数学库`math`。然后,我们分别使用`math.sqrt()`函数来求解给定数的平方根,`math.log()`函数来求解给定数的自然对数,`math.sin()`函数来求解给定角度的正弦值。最后,我们用`print()`函数将计算结果输出到屏幕上。 运行以上代码,输出结果如下: ``` The square root of 16 is 4.0 The natural logarithm of 10 is 2.302585092994046 The sine of 45 degrees is 0.7071067811865475 ``` 从以上结果可以看出,Python成功地进行了数学运算,并给出了正确的结果。 ### 6.2 编写简单的自动计算程序 除了进行简单的数学运算,我们还可以使用Python编写更复杂的自动计算程序。这些程序可以根据输入的参数,自动进行计算并给出结果。 下面是一个计算圆的周长和面积的示例代码: ```python import math # 计算圆的周长和面积 def calculate_circle(radius): circumference = 2 * math.pi * radius area = math.pi * radius ** 2 return circumference, area # 输入半径 r = float(input("请输入圆的半径:")) # 调用函数进行计算 c, a = calculate_circle(r) # 输出结果 print("圆的周长为:", c) print("圆的面积为:", a) ``` 代码解释: 首先,我们导入了Python内置的数学库`math`。然后,我们定义了一个名为`calculate_circle()`的函数,用于计算圆的周长和面积。在函数内部,我们使用了数学库`math`提供的函数来进行数学运算,并将计算结果通过`return`语句返回。 然后,我们使用`input()`函数来获取用户输入的圆的半径,并将其转换为浮点数类型。 接下来,我们调用`calculate_circle()`函数,传入半径值作为参数,并使用两个变量`c`和`a`来接收返回的结果。 最后,我们使用`print()`函数将周长和面积的结果输出到屏幕上。 用户运行程序后,将先需要输入一个半径值,然后程序会自动计算圆的周长和面积,并给出结果。例如,当用户输入半径值5时,程序将输出: ``` 圆的周长为: 31.41592653589793 圆的面积为: 78.53981633974483 ``` ### 6.3 应用案例:利用Python进行数据分析 除了进行数学计算,Python还可以应用于数据分析领域。Python提供了许多强大的库和工具,例如`pandas`、`NumPy`和`matplotlib`,可以帮助我们对数据进行处理、分析和可视化。 下面是一个简单的数据分析案例,使用`pandas`库对一个学生成绩数据进行统计和可视化: ```python import pandas as pd import matplotlib.pyplot as plt # 创建学生成绩数据 data = { '姓名': ['小明', '小红', '小刚', '小美', '小李'], '语文': [80, 90, 70, 85, 95], '数学': [85, 95, 75, 80, 90], '英语': [90, 80, 85, 95, 70] } # 将数据转换为DataFrame格式 df = pd.DataFrame(data) # 统计各科目平均成绩 df['平均成绩'] = df.mean(axis=1) # 可视化平均成绩 df.plot(x='姓名', y='平均成绩', kind='bar', color='blue') plt.xlabel('姓名') plt.ylabel('平均成绩') plt.title('学生成绩统计') plt.show() ``` 代码解释: 首先,我们导入了`pandas`库和`matplotlib.pyplot`模块。然后,我们创建了一个包含学生成绩数据的字典`data`,其中包括了学生的姓名、语文成绩、数学成绩和英语成绩。 接着,我们使用`pd.DataFrame()`函数将数据转换为`DataFrame`格式,以便进行后续的数据处理和分析。 然后,我们使用`df.mean(axis=1)`方法计算出各个学生的平均成绩,并将结果添加到DataFrame中的新列`平均成绩`中。 最后,我们使用`df.plot()`方法将学生的平均成绩可视化为柱状图,并通过`plt.xlabel()`、`plt.ylabel()`和`plt.title()`方法为图表添加标签和标题。 用户运行程序后,将会看到一个学生成绩统计的柱状图。 以上是一个简单的数据分析案例,说明了Python在数据处理和分析方面的应用能力。 本章介绍了如何使用Python进行自动计算,并给出了数学运算和数据分析的应用案例。通过学习和掌握这些内容,我们可以更好地利用Python解决实际问题和开展相关工作。
corwn 最低0.47元/天 解锁专栏
买1年送3月
点击查看下一篇
profit 百万级 高质量VIP文章无限畅学
profit 千万级 优质资源任意下载
profit C知道 免费提问 ( 生成式Al产品 )

相关推荐

SW_孙维

开发技术专家
知名科技公司工程师,开发技术领域拥有丰富的工作经验和专业知识。曾负责设计和开发多个复杂的软件系统,涉及到大规模数据处理、分布式系统和高性能计算等方面。
专栏简介
《Python语言基础与应用》专栏系统地介绍了Python语言的基础知识和其在实际应用中的技巧。从引言开始,讲述了Python语言的引用与特点,概述了Python语言的基本特征,以及Python的运行环境和第一个程序的编写和执行。同时,专栏还详细介绍了如何使用PyCharm进行Python开发,以及编程规范和数据对象组织的方法。随后,涵盖了Python基本数据类型和引用、列表、元组和字典的操作,以及集合类型和数据结构的建立等内容。同时,专栏还包含了输入输出操作、控制流程基础、函数定义与参数传递、基本模块和文本处理技术的学习,以及图形界面和绘图模块的掌握。此外,还涉及了面向对象的特性、对象排序和类的继承、异常处理和生成器技术,以及网络库和数据可视化技术的应用。通过这些内容的学习,读者可以系统地掌握Python语言的基础知识,并应用于实际开发中。
最低0.47元/天 解锁专栏
买1年送3月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
C知道 免费提问 ( 生成式Al产品 )

最新推荐

【交互特征的影响】:分类问题中的深入探讨,如何正确应用交互特征

![【交互特征的影响】:分类问题中的深入探讨,如何正确应用交互特征](https://img-blog.csdnimg.cn/img_convert/21b6bb90fa40d2020de35150fc359908.png) # 1. 交互特征在分类问题中的重要性 在当今的机器学习领域,分类问题一直占据着核心地位。理解并有效利用数据中的交互特征对于提高分类模型的性能至关重要。本章将介绍交互特征在分类问题中的基础重要性,以及为什么它们在现代数据科学中变得越来越不可或缺。 ## 1.1 交互特征在模型性能中的作用 交互特征能够捕捉到数据中的非线性关系,这对于模型理解和预测复杂模式至关重要。例如

VR_AR技术学习与应用:学习曲线在虚拟现实领域的探索

![VR_AR技术学习与应用:学习曲线在虚拟现实领域的探索](https://about.fb.com/wp-content/uploads/2024/04/Meta-for-Education-_Social-Share.jpg?fit=960%2C540) # 1. 虚拟现实技术概览 虚拟现实(VR)技术,又称为虚拟环境(VE)技术,是一种使用计算机模拟生成的能与用户交互的三维虚拟环境。这种环境可以通过用户的视觉、听觉、触觉甚至嗅觉感受到,给人一种身临其境的感觉。VR技术是通过一系列的硬件和软件来实现的,包括头戴显示器、数据手套、跟踪系统、三维声音系统、高性能计算机等。 VR技术的应用

测试集在兼容性测试中的应用:确保软件在各种环境下的表现

![测试集在兼容性测试中的应用:确保软件在各种环境下的表现](https://mindtechnologieslive.com/wp-content/uploads/2020/04/Software-Testing-990x557.jpg) # 1. 兼容性测试的概念和重要性 ## 1.1 兼容性测试概述 兼容性测试确保软件产品能够在不同环境、平台和设备中正常运行。这一过程涉及验证软件在不同操作系统、浏览器、硬件配置和移动设备上的表现。 ## 1.2 兼容性测试的重要性 在多样的IT环境中,兼容性测试是提高用户体验的关键。它减少了因环境差异导致的问题,有助于维护软件的稳定性和可靠性,降低后

【特征工程稀缺技巧】:标签平滑与标签编码的比较及选择指南

# 1. 特征工程简介 ## 1.1 特征工程的基本概念 特征工程是机器学习中一个核心的步骤,它涉及从原始数据中选取、构造或转换出有助于模型学习的特征。优秀的特征工程能够显著提升模型性能,降低过拟合风险,并有助于在有限的数据集上提炼出有意义的信号。 ## 1.2 特征工程的重要性 在数据驱动的机器学习项目中,特征工程的重要性仅次于数据收集。数据预处理、特征选择、特征转换等环节都直接影响模型训练的效率和效果。特征工程通过提高特征与目标变量的关联性来提升模型的预测准确性。 ## 1.3 特征工程的工作流程 特征工程通常包括以下步骤: - 数据探索与分析,理解数据的分布和特征间的关系。 - 特

过拟合的统计检验:如何量化模型的泛化能力

![过拟合的统计检验:如何量化模型的泛化能力](https://community.alteryx.com/t5/image/serverpage/image-id/71553i43D85DE352069CB9?v=v2) # 1. 过拟合的概念与影响 ## 1.1 过拟合的定义 过拟合(overfitting)是机器学习领域中一个关键问题,当模型对训练数据的拟合程度过高,以至于捕捉到了数据中的噪声和异常值,导致模型泛化能力下降,无法很好地预测新的、未见过的数据。这种情况下的模型性能在训练数据上表现优异,但在新的数据集上却表现不佳。 ## 1.2 过拟合产生的原因 过拟合的产生通常与模

探索性数据分析:训练集构建中的可视化工具和技巧

![探索性数据分析:训练集构建中的可视化工具和技巧](https://substackcdn.com/image/fetch/w_1200,h_600,c_fill,f_jpg,q_auto:good,fl_progressive:steep,g_auto/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fe2c02e2a-870d-4b54-ad44-7d349a5589a3_1080x621.png) # 1. 探索性数据分析简介 在数据分析的世界中,探索性数据分析(Exploratory Dat

特征贡献的Shapley分析:深入理解模型复杂度的实用方法

![模型选择-模型复杂度(Model Complexity)](https://img-blog.csdnimg.cn/img_convert/32e5211a66b9ed734dc238795878e730.png) # 1. 特征贡献的Shapley分析概述 在数据科学领域,模型解释性(Model Explainability)是确保人工智能(AI)应用负责任和可信赖的关键因素。机器学习模型,尤其是复杂的非线性模型如深度学习,往往被认为是“黑箱”,因为它们的内部工作机制并不透明。然而,随着机器学习越来越多地应用于关键决策领域,如金融风控、医疗诊断和交通管理,理解模型的决策过程变得至关重要

模型比较与选择:使用交叉验证和网格搜索评估泛化能力

![模型比较与选择:使用交叉验证和网格搜索评估泛化能力](https://community.alteryx.com/t5/image/serverpage/image-id/71553i43D85DE352069CB9/image-size/large?v=v2&px=999) # 1. 模型评估的核心概念和方法 ## 1.1 为何模型评估至关重要 在构建机器学习模型时,最终的目标是创建一个能够准确预测和分类未来数据的系统。模型评估的核心概念是测量模型在未知数据上的表现如何,以及其预测的准确性、可靠性和泛化能力。评估模型性能不仅有助于选择最佳模型,还能避免过拟合,即模型在训练数据上表现优异

【统计学意义的验证集】:理解验证集在机器学习模型选择与评估中的重要性

![【统计学意义的验证集】:理解验证集在机器学习模型选择与评估中的重要性](https://biol607.github.io/lectures/images/cv/loocv.png) # 1. 验证集的概念与作用 在机器学习和统计学中,验证集是用来评估模型性能和选择超参数的重要工具。**验证集**是在训练集之外的一个独立数据集,通过对这个数据集的预测结果来估计模型在未见数据上的表现,从而避免了过拟合问题。验证集的作用不仅仅在于选择最佳模型,还能帮助我们理解模型在实际应用中的泛化能力,是开发高质量预测模型不可或缺的一部分。 ```markdown ## 1.1 验证集与训练集、测试集的区

激活函数在深度学习中的应用:欠拟合克星

![激活函数](https://penseeartificielle.fr/wp-content/uploads/2019/10/image-mish-vs-fonction-activation.jpg) # 1. 深度学习中的激活函数基础 在深度学习领域,激活函数扮演着至关重要的角色。激活函数的主要作用是在神经网络中引入非线性,从而使网络有能力捕捉复杂的数据模式。它是连接层与层之间的关键,能够影响模型的性能和复杂度。深度学习模型的计算过程往往是一个线性操作,如果没有激活函数,无论网络有多少层,其表达能力都受限于一个线性模型,这无疑极大地限制了模型在现实问题中的应用潜力。 激活函数的基本
最低0.47元/天 解锁专栏
买1年送3月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
C知道 免费提问 ( 生成式Al产品 )