函数是一种有零个或多个参数并且有一个返回值的程序

合集下载

python方法的return数量

python方法的return数量

python方法的return数量在Python中,一个函数可以有零个或多个返回值。

返回值是函数执行完后将结果返回给调用者的一种方式。

在函数中使用return语句来指定需要返回的值。

Python中的函数返回值数量没有限制,可以返回任意数量的返回值。

下面列举了几种常见的返回值的情况:1.返回单个值:一个函数可以返回一个单独的值。

这个值可以是任意类型,如整数、浮点数、字符串、布尔值等。

例如:```pythondef add(a, b):return a + bresult = add(5, 3)print(result) # 输出 8```2. 返回多个值:Python中的函数可以返回一个由多个值组成的元组。

这样可以方便地返回多个相关的值。

例如:```pythondef divide_and_remainder(a, b):quotient = a // bremainder = a % breturn quotient, remainderresult = divide_and_remainder(10, 3)print(result) # 输出 (3, 1)```该函数返回了一个包含两个值的元组。

可以使用多个变量接收返回的元组中的值。

3.返回列表、集合或字典:函数也可以返回列表、集合或字典等可迭代对象。

例如:```pythondef get_even_numbers(n):result = []for i in range(n):if i % 2 == 0:result.append(i)return resultresult = get_even_numbers(10)print(result) # 输出 [0, 2, 4, 6, 8]```4. 不使用return语句:如果函数没有return语句,或者return后没有明确指定返回值,Python会默认返回None。

例如:```pythondef say_hello(:print("Hello")result = say_helloprint(result) # 输出 None```在函数中,return语句可以出现在任何地方,一旦执行到return语句,函数会立即停止执行,并将指定的返回值返回给调用者。

def自定义函数的语法

def自定义函数的语法

def自定义函数的语法自定义函数是在编程中非常常见和重要的概念。

它是一种允许程序员定义自己的功能或操作的机制。

自定义函数在程序设计中有着重要的作用,可以大大提高代码的复用性、可读性和可维护性。

在本文中,我将介绍自定义函数的语法以及如何使用它们来编写高效的代码。

自定义函数的语法通常由以下几个部分组成:函数头、函数体和返回值。

函数头包含了以下几个要素:1.函数名:函数的名称是在调用函数时使用的标识符,它应该具有描述函数功能的有意义的名称。

在编程规范中,通常使用小写字母和下划线命名函数,例如:calculate_sum。

2.参数列表:参数是用来传递数据给函数的变量。

参数列表是包含多个参数的括号,参数之间使用逗号分隔。

函数可以有零个或多个参数。

参数是可选的,如果函数不需要接收参数,可以在括号内留空。

例如:def calculate_sum(a, b)。

3.返回值类型:返回值是函数执行完毕后返回给调用者的结果。

在函数头的冒号后面可以添加返回值类型的声明。

例如:def calculate_sum(a, b) -> int。

例如,下面是一个计算两个数之和的自定义函数的定义:```def calculate_sum(a, b) -> int:sum = a + breturn sum```在上述代码中,函数名称是calculate_sum,它接受两个参数a和b,并且返回一个整数类型的值。

函数体中使用了赋值运算符来计算参数a和b的和,并将结果保存在变量sum中。

最后,使用关键字return返回sum的值。

自定义函数的函数体是函数的执行部分,它包含了一系列的语句和逻辑用于实现函数的功能。

函数体是缩进的代码块,所有属于函数体的语句都必须缩进相同的空格数。

在函数体中,我们可以使用各种编程语言提供的语句和控制结构来实现函数的功能。

例如,我们可以使用条件语句(if-else)、循环语句(while、for)、变量赋值语句等等。

函数的组成

函数的组成

函数的组成函数是计算机编程中的重要概念,它是一段可重复使用的代码块,用于完成特定的任务。

函数由多个组成部分构成,包括函数名、参数、返回值、函数体和函数调用。

函数名函数名是函数的标识符,用于唯一地标识一个函数。

函数名应该具有描述性,能够清晰地表达函数的作用。

函数名应该遵循命名规范,通常使用小写字母和下划线组成,以便于阅读和理解。

参数参数是函数的输入,用于传递数据给函数。

函数可以有零个或多个参数,每个参数都有一个类型和一个名称。

参数的类型指定了参数可以接受的数据类型,例如整数、浮点数、字符串等。

参数的名称用于在函数内部引用参数的值。

返回值返回值是函数的输出,用于将计算结果返回给调用者。

函数可以有一个或多个返回值,每个返回值都有一个类型和一个值。

返回值的类型指定了返回值的数据类型,例如整数、浮点数、字符串等。

返回值的值是函数计算的结果。

函数体函数体是函数的主要部分,包含了函数的实现代码。

函数体可以包含任意数量的语句,用于完成特定的任务。

函数体中可以使用参数和局部变量,以及其他函数和库函数。

函数体应该遵循代码规范,具有清晰的结构和良好的注释,以便于阅读和理解。

函数调用函数调用是使用函数的过程,用于执行函数的代码。

函数调用包括函数名和参数列表,用于指定要调用的函数和传递参数。

函数调用可以在程序的任何地方进行,可以嵌套调用其他函数,以实现复杂的计算任务。

总结函数是计算机编程中的重要概念,由多个组成部分构成,包括函数名、参数、返回值、函数体和函数调用。

函数的组成部分应该遵循命名规范和代码规范,具有清晰的结构和良好的注释,以便于阅读和理解。

函数的使用可以提高代码的可重用性和可维护性,以及提高程序的性能和效率。

函数的定义及调用方法

函数的定义及调用方法

函数的定义及调用方法在编程中,函数是一段可以重复使用的代码块,它接收输入参数并执行特定的任务,然后返回一个结果。

函数的定义和调用是编程中非常基础且重要的概念,本文将详细介绍函数的定义及调用方法。

一、函数的定义函数的定义包括函数名、参数列表、函数体和返回值。

函数名是函数的标识符,用于在程序中唯一标识该函数。

参数列表是函数接收的输入参数,可以有零个或多个参数。

函数体是函数执行的具体代码逻辑,用于实现函数的功能。

返回值是函数执行完成后返回的结果。

函数的定义一般遵循以下的语法格式:```def function_name(parameter1, parameter2, ...):# 函数体# 执行具体的任务return result```其中,`def`是定义函数的关键字,`function_name`是函数的名称,`parameter1, parameter2, ...`是函数的参数列表,`:`表示函数定义的结束,`return`用于返回函数的结果,`result`是返回的结果值。

二、函数的调用函数的调用是指使用函数名和相应的参数来执行函数。

通过函数的调用,可以在程序中多次重复使用相同的功能。

函数的调用一般遵循以下的语法格式:```result = function_name(argument1, argument2, ...)```其中,`function_name`是要调用的函数名,`argument1, argument2, ...`是要传递给函数的参数值,`result`是函数执行完成后返回的结果。

三、函数的参数函数的参数可以分为两种类型:必需参数和可选参数。

必需参数是函数定义时必须要求提供的参数,调用函数时必须传递相应的参数值。

可选参数是函数定义时给定默认值的参数,调用函数时可以选择性地传递参数值,如果不传递则使用默认值。

四、函数的返回值函数的返回值是函数执行完成后返回的结果。

在函数体中,可以使用`return`语句来返回函数的结果。

XX医学院本科各专业《Python》第五章习题与答案-2020年精品

XX医学院本科各专业《Python》第五章习题与答案-2020年精品

XX医学院本科各专业《Python》第五章习题与答案一、选择题1.Python中定义函数的关键字是(A)A.defB.defineC.functionD.defunc2. 下列不是使用函数的优点的是(D)A.减少代码重复 B.使程序更加模块化C.使程序便于阅读 D.为了展现智力优势3.关于函数参数传递中,形参与实参的描述错误的是( D)。

A.python实行按值传递参数。

值传递指调用函数时将常量或变量的值(实参)传递给函数的参数(形参)B.实参与形参存储在各自的内存空间中,是两个不相关的独立变量C.在参数内部改变形参的值,实参的值一般是不会改变的D.实参与形参的名字必须相同4. 关于Python的lambda函数,以下选项中描述错误的是(B )mbda函数将函数名作为函数结果返回B.f = lambda x,y:x+y 执行后,f的类型为数字类型mbda用于定义简单的、能够在一行内表示的函数D.可以使用lambda函数定义列表的排序原则:以下选项不是函数作用的是(A5.)A.提高代码执行速度B.增强代码可读性C.降低编程复杂度D.复用代码以下关于函数说法错误的是(D)6.:A.函数可以看做是一段具有名字的子程序B.函数通过函数名来调用C.函数是一段具有特定功能的、可重用的语句组D.对函数的使用必须了解其内部实现原理7. 以下关于函数调用描述正确的是:(A)A.自定义函数调用前必须定义B.函数在调用前不需要定义,拿来即用就好C.Python内置函数调用前需要引用相应的库D.函数和调用只能发生在同一个文件中8. 关于return语句,以下选项描述正确的是:(D)A.函数中最多只有一个return语句B.函数必须有一个return语句C.return只能返回一个值D.函数可以没有return语句9.下面说法正确的是:(B)def f(a,b):a = 4return a + bdef main():m = 5n = 6print(f(m,n),m + n)main()A.m、n为形式参数B.程序的输出结果为10 11C.a、b为实际参数D.以上说法均不正确10.以下关于Python函数说法错误的是:(B)def func(a,b):c = a ** 2 + bb = areturn ca = 10b = 100c = func(a,b) + aA.该函数名称为funcB.执行该函数后,变量c的值为200C.执行该函数后,变量a的值为10D.执行该函数后,变量b的值为10011.max()函数的作用是(C)A.求两个数的最大值B.求三个数的最大值C.返回若干数的最大值D.返回若干数的最小值()12. 哪个选项对于函数的定义是错误的?CA.def vfunc(a,*b):B.def vfunc(a,b=2):C.def vfunc(*a,b):D.def vfunc(a,b):13.下列说法错误的是(D)A.在函数内部直接修改形参的值并不影响外部实参的值。

c语言函数的概念及特点

c语言函数的概念及特点

c语言函数的概念及特点C语言中的函数是一段可重用的代码块,用于完成特定的任务。

它具有以下概念和特点:概念:1. 模块化编程:函数是C语言中模块化编程的基本单元。

通过将程序分解为多个函数,可以提高代码的可读性、可维护性和重用性。

2. 函数签名:函数由函数名和参数列表组成。

函数名是函数的标识符,用于调用函数;参数列表包含函数接受的输入参数,可以有零个或多个参数。

3. 函数体:函数体是函数的实际代码块,包含要执行的语句和算法。

函数体内可以声明局部变量、执行控制语句(如条件语句和循环语句)以及调用其他函数。

4. 返回值:函数可以有一个返回值,用于将结果返回给调用函数。

返回值可以是任意数据类型,如整数、浮点数、字符、指针等。

特点:1. 可重用性:函数可以在程序中被多次调用,提供了代码的重用性和模块化。

可以将常用的代码封装在函数中,使得代码更加简洁和易于维护。

2. 分离关注点:函数的使用使得程序的各个部分可以独立开发和调试。

每个函数负责特定的任务,使得代码更易于理解和修改。

3. 参数传递:函数通过参数列表接受输入参数。

参数可以按值传递或按引用传递。

按值传递时,参数的副本会传递给函数;按引用传递时,函数可以修改参数的值。

4. 局部变量:函数内部可以声明局部变量,这些变量仅在函数内部可见。

局部变量的作用域限于函数的范围,可以避免变量名冲突和数据污染。

5. 递归:C语言中的函数支持递归调用,即函数可以调用自身。

递归在解决一些问题时很有用,但需要小心控制递归的结束条件,以避免无限递归导致程序崩溃。

函数是C语言中的重要概念,它们为程序提供了模块化、可重用的代码结构,提高了程序的可读性、可维护性和灵活性。

通过合理使用函数,可以编写出结构良好、高效的C程序。

函数基本知识点总结

函数基本知识点总结

函数基本知识点总结一、函数的定义函数是一段封装了特定功能的代码块,它可以有零个或多个输入参数,也可以有一个返回值。

函数能够提高代码的模块化程度和可维护性,同时还能够减少重复编写相同功能的代码,提高代码的复用性。

在大多数编程语言中,函数的定义通常包括函数名称、参数列表、返回类型和函数体。

例如,在C语言中,函数的定义如下:```cint max(int a, int b) {return a > b ? a : b;}```上面的代码定义了一个名为max的函数,它接受两个整数类型的参数a和b,并返回一个整数类型的结果。

函数体中使用了条件表达式来判断a和b的大小关系,然后返回较大的一个值。

二、函数的声明在使用函数之前,通常需要提前声明函数的存在,也就是告诉编译器函数的名称、参数列表和返回类型。

函数的声明通常放在头文件中,以便在不同源文件中共享函数的声明。

例如,在C语言中,max函数的声明如下:```cint max(int a, int b);```上面的代码定义了max函数的声明,告诉编译器max函数接受两个整数类型的参数a和b,并返回一个整数类型的结果。

三、函数的调用在程序中,函数通过函数名和实参列表进行调用,以执行其中的代码。

函数调用时,实参会传给形参,然后函数执行相应的操作,并可能返回一个值。

例如,调用上面定义的max 函数的方式如下:int a = 10, b = 20;int result = max(a, b);```上面的代码调用了max函数,传入了整数变量a和b作为实参,并将返回的结果保存在result变量中。

四、函数的参数传递函数的参数传递有两种方式:值传递和引用传递。

在值传递中,函数的形参是实参的副本,对形参的修改不会影响实参。

而在引用传递中,函数的形参是实参的引用,对形参的修改会影响实参。

在C语言中,函数的参数传递通常是通过值传递实现的。

例如,上面定义的max函数即是通过值传递进行参数传递的。

mysql中create function的用法

mysql中create function的用法

mysql中create function的用法"mysql中create function的用法"在MySQL中,CREATE FUNCTION语句用于创建一个自定义函数(Function)。

函数是一种可重复使用的代码块,用于执行特定任务并返回一个值。

通过使用CREATE FUNCTION语句,我们可以在MySQL中创建自己的函数,以便在查询中使用。

下面是使用CREATE FUNCTION创建函数的逐步介绍:步骤1:了解函数的语法在使用CREATE FUNCTION创建函数之前,我们需要了解函数的语法规则。

以下是CREATE FUNCTION语句的一般语法:sqlCREATE FUNCTION function_name (parameter1 type, parameter2 type, ...)RETURNS return_type[characteristic...]BEGIN函数体END;在上面的语法中,function_name是函数的名称,parameter1,parameter2等是函数的参数,type是参数的数据类型,return_type是函数的返回类型,characteristic是函数的特性(例如,是否确定性或不确定性)。

步骤2:定义函数的参数在创建函数之前,我们需要确定函数的参数。

函数可以有零个或多个参数,每个参数都有一个名称和数据类型。

下面是一个例子:sqlCREATE FUNCTION calculate_average (param1 INT, param2 INT)在上面的例子中,我们创建了一个名为calculate_average的函数,该函数有两个整数类型的参数。

步骤3:确定函数的返回值在创建函数之前,我们还需要确定函数的返回类型。

函数可以返回不同类型的值,如整数,浮点数,字符串等。

以下是一个示例:sqlCREATE FUNCTION calculate_average (param1 INT, param2 INT) RETURNS FLOAT在上面的示例中,我们确定了calculate_average函数的返回类型为浮点数(FLOAT)。

函数知识点基础总结

函数知识点基础总结

函数知识点基础总结函数的定义函数的定义包括函数名、参数列表、函数体和返回值。

函数名是标识符,用来唯一标识一个函数;参数列表包括零个或多个参数,参数是函数接受的输入;函数体是一段包含了操作和逻辑的代码块;返回值是函数执行完成后返回的结果。

在不同的编程语言中,函数的定义方式有所不同,以下是一些常见的编程语言中函数定义的示例。

在C语言中,函数的定义如下:```cint add(int a, int b) {return a + b;}```在Python中,函数的定义如下:```pythondef add(a, b):return a + b```参数和返回值函数的参数是函数接受的输入,可以有零个或多个参数。

在函数调用时,实际参数的值会传递给形式参数,然后在函数体内进行操作。

函数的返回值是函数执行后的结果,可以有零个或一个返回值。

在函数体中使用关键字 `return` 来返回结果。

在C语言中,函数参数的使用如下:```cint main() {int a = 1, b = 2;int result = add(a, b);printf("%d\n", result);}```在Python中,函数参数的使用如下:```pythonresult = add(1, 2)print(result)```作用域作用域是指变量的有效范围,函数内部定义的变量只能在函数内部使用,而不能在函数外部访问。

在一些编程语言中,作用域分为全局作用域和局部作用域。

全局作用域是指整个程序范围内可访问的变量,而局部作用域是指函数内部可访问的变量。

在函数内部定义的变量称为局部变量,它的作用域只在函数内部。

在函数外部定义的变量称为全局变量,它的作用域在整个程序中。

在C语言中,全局变量和局部变量的使用如下:```cint global_var = 10;int main() {int local_var = 5;printf("%d\n", global_var); // 可以访问全局变量printf("%d\n", local_var); // 可以访问局部变量return 0;}```在Python中,全局变量和局部变量的使用如下:```pythonglobal_var = 10local_var = 5print(global_var) # 可以访问全局变量print(local_var) # 可以访问局部变量```递归递归是指函数调用自身的过程,通过递归可以实现一些复杂的任务。

if函数原理

if函数原理

if函数原理函数的原理是计算机程序中非常重要的概念之一、它是一种可重复使用的代码块,用于执行特定的任务或计算,并返回一个结果。

函数具有输入和输出,可以接受参数并返回值。

在计算机科学中,函数被广泛用于模块化程序,提高代码的可读性,降低代码的重复性,并简化复杂的问题。

函数的原理可以分为以下几个方面来理解。

1.封装和抽象:函数将一系列的代码封装成一个独立的单元,将其称为函数体。

函数隐藏了底层的实现细节,只需要关注其输入和输出即可。

这种封装和抽象的特性使得函数更容易被理解和使用,也方便了代码的维护和修改。

2.代码重用:函数是一种代码的重用机制。

将相同或相似的代码封装在函数中,可以在程序的不同地方多次调用。

这样一方面可以减少代码的重复性,提高开发效率;另一方面也方便了对代码的修改和更新,只需要改动函数的定义即可,而不需要在多处地方进行修改。

3.模块化和组织:函数是程序的基本构建模块之一,通过将程序分解成多个函数,可以将复杂的问题分解为更小的子问题,更易于理解和解决。

函数可以按照功能或任务的不同进行划分和组织,使得程序的结构更加清晰,可读性更高。

4.参数和返回值:函数可以接受参数来进行计算和处理。

参数是函数的输入,可以用来传递数据或配置函数的行为。

根据需要,函数可以有零个或多个参数。

函数会根据输入的参数执行相应的逻辑,并最终返回一个结果。

这种参数和返回值的机制使得函数可以更加灵活地适应不同的具体问题。

5.作用域和可见性:函数可以创建独立的作用域,函数内部定义的变量只在函数内部可见,不会与其他部分发生命名冲突。

这种作用域机制提供了更好的封装和隔离性,使得函数可以更加独立和可靠。

函数也可以访问外部作用域的变量,并可以修改这些变量的值,但需要遵循一定的规则,以确保程序的正确性。

6.递归:函数可以调用其他函数,也可以调用自身。

当函数调用本身的过程称为递归。

递归有助于解决一些复杂的问题,可以将它们分解成更小的子问题,从而更容易理解和解决。

lambda表达式实现原理

lambda表达式实现原理

lambda表达式实现原理Lambda表达式实现原理什么是Lambda表达式?Lambda表达式是一种简洁的匿名函数表示方法,它可以被当作一个变量使用,具有函数体、参数和返回值。

在函数式编程中,Lambda 表达式常常用于简化代码,增加可读性和代码的精简度。

Lambda表达式的语法结构Lambda表达式的语法结构如下:(parameters) -> expression其中,parameters为参数列表,expression为函数体表达式。

Lambda表达式可以有零个或多个参数,参数之间用逗号隔开。

Lambda表达式的实质Lambda表达式实际上是一个对象,它是一个函数式接口的实例。

所谓函数式接口,就是只包含一个抽象方法的接口。

Lambda表达式可以被转化为函数式接口的实例,进而可以赋值给一个该接口类型的变量。

Lambda表达式本质上是通过接口的实现类来实现的。

Lambda表达式的工作原理Lambda表达式背后的实现原理可以分为以下步骤:1.解析Lambda表达式结构:根据Lambda表达式的外观,解析出参数和函数体等结构。

2.创建函数式接口的实例:根据Lambda表达式的结构,创建一个匿名类的实例,该实例实现了函数式接口。

3.调用接口的方法:通过创建的实例,调用函数式接口中的抽象方法,执行Lambda表达式的函数体。

Lambda表达式的解析和创建过程是在编译阶段进行的,而实际执行则是在运行阶段。

Lambda表达式的优点•减少了代码的冗余:Lambda表达式可以大大减少代码的长度,增加了代码的可读性和简洁度。

•便于并行处理:Lambda表达式可以方便地实现并行处理,提升程序的性能。

•更好地支持函数式编程:Lambda表达式是函数式编程的重要特性,在某些场景下可以更方便地使用函数式编程的思想。

总结本文介绍了Lambda表达式的实现原理及其优点。

Lambda表达式是一种简洁的匿名函数表示方法,其实质是一个函数式接口的实例。

函数扩展知识点

函数扩展知识点

函数扩展知识点函数是编程中非常重要的概念。

它允许我们将代码块组织成可重复使用的模块,并且在需要的时候调用它们。

在本文中,我们将探讨一些函数的扩展知识点,包括函数的参数、返回值和作用域。

函数的参数函数的参数是函数定义中用来接收输入值的变量。

通过参数,我们可以将数据传递给函数并在函数内部进行操作。

函数可以有零个或多个参数。

定义函数时,我们可以在括号内指定函数的参数。

参数之间使用逗号分隔。

下面是一个简单的示例:def greet(name):print("Hello", name)greet("Alice")在这个例子中,greet函数接受一个参数name,并在函数体内打印出“Hello”加上参数的值。

除了普通参数,函数还可以接受默认参数。

默认参数在函数定义时指定,并且在函数调用时可以省略。

如果省略了默认参数,则函数使用指定的默认值。

下面是一个示例:def greet(name, greeting="Hello"):print(greeting, name)greet("Alice") # 输出 "Hello Alice"greet("Bob", "Hi") # 输出 "Hi Bob"在这个例子中,greet函数接受两个参数,name和greeting。

greeting参数有一个默认值“Hello”。

如果不提供greeting参数的值,函数将使用默认值。

函数的返回值函数可以返回一个值,这个值可以在函数调用的地方使用。

要指定一个返回值,我们可以使用return语句。

下面是一个示例:def add(a, b):return a + bresult = add(3, 4)print(result) # 输出 7在这个例子中,add函数接受两个参数a和b,将它们相加后返回结果。

PLSQL函数

PLSQL函数

plsql常用方法在SQLPLUS下,实现中-英字符集转换alter session set nls_language='AMERICAN';alter session set nls_language='SIMPLIFIED CHINESE';主要知识点:一、有关表的操作1)建表create table test as select * from dept; --从已知表复制数据和结构create table test as select * from dept where 1=2; --从已知表复制结构但不包括数据2)插入数据:insert into test select * from dept;二、运算符算术运算符:+ - * / 可以在select 语句中使用连接运算符:|| select deptno|| dname from dept;比较运算符:> >= = != < <= like between is null in逻辑运算符:not and or集合运算符:intersect ,union,union all,minus要求:对应集合的列数和数据类型相同查询中不能包含long 列列的标签是第一个集合的标签使用order by时,必须使用位置序号,不能使用列名例:集合运算符的使用:intersect ,union,union all,minusselect * from emp intersect select * from emp where deptno=10 ;select * from emp minus select * from emp where deptno=10;select * from emp where deptno=10 union select * from emp where deptno in (10,20); --不包括重复行select * from emp where deptno=10 union all select * from emp where deptno in (10,20); --包括重复行三,常用ORACLE 函数sysdate为系统日期dual为虚表一)日期函数[重点掌握前四个日期函数]1,add_months[返回日期加(减)指定月份后(前)的日期]select sysdate S1,add_months(sysdate,10) S2,add_months(sysdate,5) S3 from dual;2,last_day [返回该月最后一天的日期]select last_day(sysdate) from dual;3,months_between[返回日期之间的月份数]select sysdate S1, months_between('1-4月-04',sysdate) S2,months_between('1-4月-04','1-2月-04') S3 from dual4,next_day(d,day): 返回下个星期的日期,day为1-7或星期日-星期六,1表示星期日select sysdate S1,next_day(sysdate,1) S2,next_day(sysdate,'星期日') S3 FROM DUAL5,round[舍入到最接近的日期](day:舍入到最接近的星期日)select sysdate S1,round(sysdate) S2 ,round(sysdate,'year') YEAR,round(sysdate,'month') MONTH ,round(sysdate,'day') DAY from dual6,trunc[截断到最接近的日期]select sysdate S1,trunc(sysdate) S2,trunc(sysdate,'year') YEAR,trunc(sysdate,'month') MONTH ,trunc(sysdate,'day') DAY from dual7,返回日期列表中最晚日期select greatest('01-1月-04','04-1月-04','10-2月-04') from dual二)字符函数(可用于字面字符或数据库列)1,字符串截取select substr('abcdef',1,3) from dual2,查找子串位置select instr('abcfdgfdhd','fd') from dual3,字符串连接select 'HELLO'||'hello world' from dual;4, 1)去掉字符串中的空格select ltrim(' abc') s1,rtrim('zhang ') s2,trim(' zhang ') s3 from dual2)去掉前导和后缀select trim(leading 9 from 9998767999) s1,trim(trailing 9 from 9998767999) s2,trim(9 from 9998767999) s3 from dual;5,返回字符串首字母的Ascii值select ascii('a') from dual6,返回ascii值对应的字母select chr(97) from dual7,计算字符串长度select length('abcdef') from dual8,initcap(首字母变大写),lower(变小写),upper(变大写)select lower('ABC') s1,upper('def') s2,initcap('efg') s3 from dual;9,Replaceselect replace('abc','b','xy') from dual;10,translateselect translate('abc','b','xx') from dual; -- x是1位11,lpad [左添充] rpad [右填充](用于控制输出格式)select lpad('func',15,'=') s1, rpad('func',15,'-') s2 from dual;select lpad(dname,14,'=') from dept;12, decode[实现if ..then 逻辑]select deptno,decode(deptno,10,'1',20,'2',30,'3','其他') from dept;三)数字函数1,取整函数(ceil 向上取整,floor 向下取整)select ceil(66.6) N1,floor(66.6) N2 from dual;2, 取幂(power) 和求平方根(sqrt)select power(3,2) N1,sqrt(9) N2 from dual;3,求余select mod(9,5) from dual;4,返回固定小数位数(round:四舍五入,trunc:直接截断)select round(66.667,2) N1,trunc(66.667,2) N2 from dual;5,返回值的符号(正数返回为1,负数为-1)select sign(-32),sign(293) from dual;四)转换函数1,to_char()[将日期和数字类型转换成字符类型]1) select to_char(sysdate) s1,to_char(sysdate,'yyyy-mm-dd') s2,to_char(sysdate,'yyyy') s3,to_char(sysdate,'yyyy-mm-dd hh12:mi:ss') s4,to_char(sysdate, 'hh24:mi:ss') s5,to_char(sysdate,'DAY') s6 from dual;2) select sal,to_char(sal,'$99999') n1,to_char(sal,'$99,999') n2 from emp2, to_date()[将字符类型转换为日期类型]insert into emp(empno,hiredate) values(8000,to_date('2004-10-10','yyyy-mm-dd')); 3, to_number() 转换为数字类型select to_number(to_char(sysdate,'hh12')) from dual; //以数字显示的小时数五)其他函数user:返回登录的用户名称select user from dual;vsize:返回表达式所需的字节数select vsize('HELLO') from dual;nvl(ex1,ex2):ex1值为空则返回ex2,否则返回该值本身ex1(常用)例:如果雇员没有佣金,将显示0,否则显示佣金select comm,nvl(comm,0) from emp;nullif(ex1,ex2):值相等返空,否则返回第一个值例:如果工资和佣金相等,则显示空,否则显示工资select nullif(sal,comm),sal,comm from emp;coalesce:返回列表中第一个非空表达式select comm,sal,coalesce(comm,sal,sal*10) from emp;nvl2(ex1,ex2,ex3) :如果ex1不为空,显示ex2,否则显示ex3如:查看有佣金的雇员姓名以及他们的佣金select nvl2(comm,ename,') as HaveCommName,comm from emp;六)分组函数max min avg count sum1,整个结果集是一个组1) 求部门30 的最高工资,最低工资,平均工资,总人数,有工作的人数,工种数量及工资总和select max(ename),max(sal),min(ename),min(sal),avg(sal),count(*) ,count(job),count(distinct(job)) ,sum(sal) from emp where deptno=30;2, 带group by 和having 的分组1)按部门分组求最高工资,最低工资,总人数,有工作的人数,工种数量及工资总和select deptno, max(ename),max(sal),min(ename),min(sal),avg(sal),count(*) ,count(job),count(distinct(job)) ,sum(sal) from emp group by deptno;2)部门30的最高工资,最低工资,总人数,有工作的人数,工种数量及工资总和select deptno, max(ename),max(sal),min(ename),min(sal),avg(sal),count(*) ,count(job),count(distinct(job)) ,sum(sal) from emp group by deptno having deptno=30;3, stddev 返回一组值的标准偏差select deptno,stddev(sal) from emp group by deptno;variance 返回一组值的方差差select deptno,variance(sal) from emp group by deptno;4, 带有rollup和cube操作符的Group Byrollup 按分组的第一个列进行统计和最后的小计cube 按分组的所有列的进行统计和最后的小计select deptno,job ,sum(sal) from emp group by deptno,job;select deptno,job ,sum(sal) from emp group by rollup(deptno,job);cube 产生组内所有列的统计和最后的小计select deptno,job ,sum(sal) from emp group by cube(deptno,job);七、临时表只在会话期间或在事务处理期间存在的表.临时表在插入数据时,动态分配空间create global temporary table temp_dept(dno number,dname varchar2(10))on commit delete rows;insert into temp_dept values(10,'ABC');commit;select * from temp_dept; --无数据显示,数据自动清除on commit preserve rows:在会话期间表一直可以存在(保留数据)on commit delete rows:事务结束清除数据(在事务结束时自动删除表的数据)1.0摘要//简要说明该文档内容SQL是用来访问关系型数据库一种通用语言,其执行特点是非过程化,即不用指明执行的具体方法和途径,而是简单的调用相应语句来直接取得结果即可。

函数的概念通俗理解

函数的概念通俗理解

函数的概念通俗理解
函数是编程中非常重要的概念,它是一段可以被重复使用的代码块,可以接受输入参数并返回输出结果。

在程序设计中,函数可以帮助我们更好地组织和管理代码,提高代码的复用性和可读性。

首先,我们来看一下函数的定义。

函数通常由函数名、参数列表、函数体和返回值组成。

函数名是函数的标识符,用来唯一标识一个函数;参数列表是函数接受的输入,可以有零个或多个参数;函数体是函数的具体实现,包括了一系列的操作和逻辑;返回值是函数执行完毕后返回的结果。

函数的作用非常广泛,它可以用来完成各种不同的任务。

比如,我们可以编写一个函数来计算两个数的和,这样在程序中多次需要计算两个数的和时,就可以直接调用这个函数,而不需要重复编写相同的代码。

这不仅提高了代码的复用性,还可以减少错误的发生。

另外,函数还可以帮助我们更好地组织和管理代码。

通过将一些功能相对独立的代码块封装成函数,可以让程序结构更加清晰,便于阅读和维护。

同时,函数还可以提高代码的可读性,因为通过函数名和参数列表就可以清楚地知道这个函数是做什么用的,需要什么样的输入。

除此之外,函数还可以提高程序的性能。

通过将一些频繁使用的操作封装成函数,可以减少重复代码的出现,提高代码的执行效率。

同时,函数还可以提高代码的可测试性,因为每个函数都可以单独进行测试,确保其功能的正确性。

总之,函数是编程中非常重要的概念,它可以帮助我们更好地组织和管理代码,提高代码的复用性和可读性,同时还可以提高程序的性能和可测试性。

因此,在编程过程中,我们应该充分利用函数这一工具,合理地设计和使用函数,从而写出高质量、高效率的代码。

函数知识点总结入门初中

函数知识点总结入门初中

函数知识点总结入门初中函数的定义和调用:在大多数编程语言中,函数的定义通常包含函数名、参数列表、函数体和返回值。

函数名用来唯一标识函数,参数列表用来接收输入的数据,函数体包含了函数的具体实现,返回值用来输出结果。

函数的调用是指在程序中使用函数来执行特定的操作。

当程序执行到函数调用的位置时,会跳转到函数定义的位置执行函数体中的代码,然后返回结果后继续执行函数调用位置后面的代码。

参数和返回值:函数可以有零个或多个参数,参数用来接收函数调用时传递的数据。

参数可以是任意类型的数据,比如整数、浮点数、字符串、列表等。

在函数定义时需要指定参数的类型和名称,在函数调用时需要传递相应的参数值。

返回值用来输出函数执行的结果,一个函数可以返回零个或一个值。

在函数定义时需要指定返回值的类型,当函数执行完成后会将结果返回给调用者。

函数的重载和默认参数:一些编程语言支持函数的重载,即定义多个同名函数但参数列表不同的函数。

这样可以根据传入的参数类型和数量来调用不同的函数,提高了函数的灵活性。

另外一些编程语言支持默认参数,即在函数定义时可以给参数指定默认值。

这样在调用函数时如果没有传入参数值,就会使用默认值。

这样可以简化函数调用,避免重复输入相同的参数。

局部变量和全局变量:在函数中定义的变量叫做局部变量,只能在函数体内部访问。

局部变量的作用域仅限于定义它的函数,当函数执行结束后,局部变量就被销毁了。

全局变量是在函数外部定义的变量,可以在整个程序中被访问。

全局变量的作用域是整个程序,但需要注意全局变量可能会被函数中重新定义的同名变量所覆盖。

递归函数:递归函数是一种特殊的函数,可以直接或者间接地调用自身。

递归函数通常用于解决一些需要重复执行相同逻辑的问题,比如阶乘、斐波那契数列等。

递归函数需要有一个基本条件(递归出口)和递归条件,否则会导致无限递归。

匿名函数:匿名函数也叫做Lambda函数,是一种不需要通过函数名来定义的函数。

匿名函数通常用于需要传递函数作为参数的场景,比如排序算法、列表操作等。

函数的定义通俗易懂

函数的定义通俗易懂

函数的定义在计算机编程中,函数是一段可重复使用的代码块,用于执行特定的任务。

函数可以接收输入参数,并根据这些参数进行计算或操作,最后返回一个结果。

函数的定义包括函数名、参数列表、返回值类型和函数体。

1.函数名:函数名是用来调用该函数的标识符。

它应该具有描述性,并且能够清楚地表达出函数的功能。

2.参数列表:参数是传递给函数的值,用于在函数内部进行处理。

参数列表包括多个参数,每个参数由类型和名称组成。

可以有零个或多个参数。

3.返回值类型:返回值是从函数中返回给调用者的结果。

返回值类型指定了返回值的数据类型。

4.函数体:函数体是一系列语句块,用于实现特定的功能。

在函数体中可以使用条件语句、循环语句、变量等来完成任务。

函数的用途函数在编程中起到了模块化和重用代码的作用,使得程序更加易读、易维护和可扩展。

以下是一些常见的使用场景:1.封装代码:将一段功能性代码封装成一个独立的函数,可以提高代码可读性和可维护性。

这样其他开发人员只需要调用该函数即可完成相应功能,无需关心函数内部的具体实现。

2.提高代码重用性:通过将一段通用的功能代码封装成函数,可以在不同的地方多次调用。

这样可以避免代码的重复编写,提高代码的重用性和开发效率。

3.简化程序结构:通过将复杂的任务拆分成多个函数,可以使程序结构更加清晰和易于理解。

每个函数负责完成一个特定的子任务,使得整个程序更易于维护和调试。

4.提高可测试性:通过将程序拆分成多个小函数,可以实现单元测试。

这样可以针对每个函数进行独立的测试,以保证其正确性。

函数的工作方式当一个函数被调用时,程序会跳转到该函数,并执行其中的代码。

在执行过程中,会按照参数列表中定义的顺序传递参数给函数。

然后,在函数体中对这些参数进行处理,并根据需要执行一系列操作。

最后,根据返回值类型定义,返回一个结果给调用者。

以下是一般情况下函数的工作方式:1.传递参数:调用者在调用函数时提供参数值,并按照参数列表中定义的顺序传递给函数。

什么是函数?

什么是函数?

什么是函数?函数是编程中常用的概念之一。

它是一段封装了特定功能的代码,可以在程序中被多次调用和重用。

一个函数可以接受输入参数,执行一系列操作,并返回一个输出结果。

函数的定义函数可以用以下方式定义:def 函数名(参数1, 参数2, ...):函数体执行的操作return 返回值- `def`关键字用于定义函数。

- `函数名`是函数的标识符,用来调用函数。

- `(参数1, 参数2, ...)`是函数的参数列表,可以有零个或多个参数。

- `函数体`是函数的具体实现,包含了函数要执行的操作。

- `return`语句用于返回函数的输出结果。

函数的调用函数的调用是指在程序中使用函数并传递相应的参数来执行函数体中的操作。

结果 = 函数名(参数1, 参数2, ...)- `结果`是函数的返回值,可以使用它来接收函数的输出结果。

- `函数名`是之前定义的函数名。

- `(参数1, 参数2, ...)`是传递给函数的输入参数。

函数的优点函数的使用有以下几个优点:- 模块化和重用:函数能够将复杂的任务分解为更小的可管理的部分,提高代码的可读性、可维护性和可重用性。

模块化和重用:函数能够将复杂的任务分解为更小的可管理的部分,提高代码的可读性、可维护性和可重用性。

- 简化代码:通过使用函数,可以将重复的代码块封装起来,简化代码,并减少代码量。

简化代码:通过使用函数,可以将重复的代码块封装起来,简化代码,并减少代码量。

- 提高效率:函数的使用可以使程序更高效,因为可以避免重复的计算和操作。

提高效率:函数的使用可以使程序更高效,因为可以避免重复的计算和操作。

- 分工协作:函数的使用使得多人协作开发更加容易,因为可以将任务分配给不同的人负责实现相应的函数。

分工协作:函数的使用使得多人协作开发更加容易,因为可以将任务分配给不同的人负责实现相应的函数。

总结函数是编程中的重要概念,它能够封装特定功能的代码,并在程序中被多次调用和重用。

函数知识点总结六年级上册

函数知识点总结六年级上册

函数知识点总结六年级上册一、函数的概念函数是数学中的重要概念,它描述了两个变量之间的关系。

在数学中,函数通常表示为一个特定的输入值对应到一个输出值的关系。

函数可以用来描述各种各样的变化规律和数学关系。

在程序设计中,函数被用来封装一系列操作,方便代码的重用和维护。

二、函数的表示在数学中,函数通常用 f(x) 表示,其中 x 是自变量,f(x) 是关于 x 的函数值。

在编程中,函数通常用关键字 def 来定义,然后在函数名后面跟上函数的参数列表和函数体。

三、函数的调用当函数定义好之后,需要通过函数的名称和参数来调用函数。

在调用函数时,程序会执行函数体中的操作,并且根据函数的返回值进行相应的处理。

四、函数的参数函数可以有零个或多个参数,参数是传递给函数的信息。

在函数的定义和调用中需要明确函数的参数列表和参数的类型。

五、函数的返回值函数可以返回一个值,也可以返回多个值。

返回值可以用来描述函数执行的结果,也可以用来传递函数的输出。

六、函数的作用域函数内部定义的变量叫做局部变量,只能在函数内部使用。

函数外部定义的变量叫做全局变量,可以在整个程序中使用。

七、递归函数递归函数是指在函数定义中调用函数本身的函数。

递归函数可以用来描述许多数学问题和计算问题,如阶乘、斐波那契数列等。

八、Lambda函数Lambda函数是一种匿名函数,它不需要显式地进行命名。

Lambda函数通常用于一些简单的函数操作,可以直接在表达式中定义函数。

九、高阶函数高阶函数是指接受一个或多个函数作为参数,并返回一个函数的函数。

高阶函数可以用来描述许多复杂的计算和逻辑操作。

十、偏函数偏函数是指通过固定函数的部分参数,从而得到一个新的函数。

十一、封装与抽象函数可以用来封装一系列操作,从而方便代码的重用和维护。

函数的抽象性使得我们能够更好地理解和使用函数。

十二、函数的重用函数可以被多次调用,从而实现代码的重用。

函数的重用性使得我们可以在不同的场景中使用同一个函数。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

函数是一种有零个或多个参数并且有一个返回值的程序函数是一种有零个或多个参数并且有一个返回值的程序。

在中内建了一系列函SQLOracle数,这些函数都可被称为或语句,函数主要分为两大类:单行函数、组函数。

SQLPL/SQL、中的单行函数1SQL和中自带很多类型的函数,有字符、数字、日期、转换、和混合型等多种SQLPL/SQL函数用于处理单行数据,因此这些都可被统称为单行函数。

这些函数均可用于、等子句中,例如下面的例子中就包含了SELECT,WHEREORDER BY等单行函数。

TO_CHAR,UPPER,SOUNDEXSELECT ename,TO_CHAR(hiredate,'day,DD-Mon-YYYY')FROM emp Where UPPER(ename)Like 'AL%'ORDER BY SOUNDEX(ename)单行函数也可以在其他语句中使用,如的子句,的子句,updateSETINSERTVALUES的子句认证考试特别注意在语句中使用这些函数,所以我们的注DELETWHERE,SELECT意力也集中在语句中。

SELECT和单行函数NULL在如何理解上开始是很困难的,就算是一个很有经验的人依然对此感到困惑。

NULL值表示一个未知数据或者一个空值,算术操作符的任何一个操作数为值,结NULLNULL果均为提个值这个规则也适合很多函数,只有NULL,在调用了参数时能够返回非值。

CONCAT,DECODE,DUMP,NVL,REPLACENULLNULL在这些中函数时最重要的,因为他能直接处理值,有两个参数:NVLNULLNVL 和都是表达式,当为时返回否则返回。

NVL(x1,x2),x1x2x1nullX2,x1下面我们看看数据表它包含了薪水、奖金两项,需要计算总的补偿empcolumn name emp_id salary bonuskey type pk nulls/unique nn,u nnfk table datatype numbernumber numberlength 11.2 11.2不是简单的将薪水和奖金加起来就可以了,如果某一行是值那么结果就将是,nullnull比如下面的例子:update emp set salary=(salary+bonus)*1.1这个语句中,雇员的工资和奖金都将更新为一个新的值,但是如果没有奖金,即 salary那么就会得出错误的结论,这个时候就要使用函数来排除值的影响。

+null,nvlnull 所以正确的语句是:update emp set salary=(salary+nvl(bonus,0)*1.1 单行字符串函数单行字符串函数用于操作字符串数据,他们大多数有一个或多个参数,其中绝大多数返回字符串ASCII()是一字符串,返回第一个字母的码,他的逆函数是c1c1ASCIICHR() SELECT ASCII('A') BIG_A,ASCII('z') BIG_z FROM empBIG_A BIG_z65 122 ,,CHR(i)[NCHAR_CS]是一个数字,函数返回十进制表示的字符iselect CHR(65),CHR(122),CHR(223) FROM empCHR65 CHR122 CHR223A z B CONCAT(,)均为字符串,函数将连接到的后面,如果为将返回如果为c1,c2c2c1c1null,c2.c2null,则返回,如果、都为,则返回。

他和操作符返回的结果相同c1c1c2nullnull||select concat('slobo ','Svoboda') username from dualusernameslobo SyobodaINITCAP()为一字符串。

函数将每个单词的第一个字母大写其它字母小写返回。

单词由空格,c1控制字符,标点符号限制。

select INITCAP('veni,vedi,vici') Ceasar fromdualCeasarVeni,Vedi,Vici,,INSTR(,[,i[,]])均为字符串,为整数。

函数返回在中第次出现的位置,搜索从的第c1,c2i,jc2c1jc1个字符开始。

当没有发现需要的字符时返回如果为负数,那么搜索将从右到左进行,i0,i但是位置的计算还是从左到右,和的缺省值为ij1.select INSTR('Mississippi','i',3,3) fromdualINSTR('MISSISSIPPI','I',3,3)11selectINSTR('Mississippi','i',-2,3) from dualINSTR('MISSISSIPPI','I',3,3)2 INSTRB(,[,i[,j])与()函数一样,只是他返回的是字节,对于单字节等于INSTRINSTRB()INSTR() LENGTH()为字符串,返回的长度,如果为,那么将返回值。

c1c1c1nullnullselect LENGTH('Ipso Facto') ergo from dualergo10LENGTHb()与一样,返回字节。

LENGTH()lower()返回的小写字符,经常出现在子串中cwhereselect LOWER(colorname) from itemdetail WHERE LOWER(colorname) LIKE '%white%'COLORNAMEWinterwhite,,LPAD(,i[,])均为字符串,为整数。

在的左侧用字符串补足致长度可多次重复,如果c1,c2ic1c2i,小于的长度,那么只返回那么长的字符,其他的将被截去。

的缺省值为单空格,ic1ic1c2参见。

RPADselect LPAD(answer,7,'') padded,answer unpadded from question;PADDED UNPADDED YesYesNO NOMaybe maybeLTRIM(,)把中最左边的字符去掉,使其第一个字符不在中,如果没有,那么就不会c1c2c2c1改变。

select LTRIM('Mississippi','Mis') from dualLTRppi,,RPAD(,i[,])在的右侧用字符串补足致长度可多次重复,如果小于的长度,那么只返回c1c2i,ic1那么长的字符,其他的将被截去。

的缺省值为单空格其他与相似ic1c2,LPAD RTRIM(,)把中最右边的字符去掉,使其第后一个字符不在中,如果没有,那么就不c1c2c2c1会改变。

REPLACE(,[,])都是字符串,函数用代替出现在中的后返回。

c1,c2,c3c3c1c2select REPLACE('uptown','up','down') from dualREPLACEdowntown,,STBSTR(,i[,])为一字符串,为整数,从的第位开始返回长度为的子字符串,如果为空,c1i,jc1ijj则直到串的尾部。

select SUBSTR('Message',1,4) from dualSUBSMess,,SUBSTRB(,i[,])与大致相同,只是是以字节计算。

SUBSTRI,JSOUNDEX()返回与发音相似的词c1select SOUNDEX('dawes') Dawes SOUNDEX('daws') Daws, SOUNDEX('dawson') fromdualDawes Daws DawsonD200 D200 D250TRANSLATE(,,)将中与相同的字符以代替c1c2c3select TRANSLATE('fumble','uf','ar') test from dualTEXTrambleTRIM([[]] from c3)将串中的第一个,最后一个,或者都删除。

c3select TRIM(' space padded ') trim from dual TRIMspace paddedUPPER()返回的大写,常出现子串中c1whereselect name from dual where UPPER(name) LIKE 'KI%'NAMEKING单行数字函数单行数字函数操作数字数据,执行数学和算术运算。

所有函数都有数字参数并返回数字值。

所有三角函数的操作数和值都是弧度而不是角度,没有提供内建的弧度和角度的oracle转换函数。

ABS()返回的绝对值nACOS()反余玄函数,返回到之间的数。

表示弧度-11nselect ACOS(-1) pi,ACOS(1) ZERO FROM dualPI ZERO3.14159265 0ASIN()反正玄函数,返回到,表示弧度-11nATAN()反正切函数,返回的反正切值,表示弧度。

nnCEIL()返回大于或等于的最小整数。

nCOS()返回的余玄值,为弧度nnCOSH()返回的双曲余玄值,为数字。

nnselect COSH(<1.4>) FROM dualCOSH(1.4)2.15089847EXP()返回的次幂,ene=2.71828183.FLOOR()返回小于等于的最大整数。

NLN()返回的自然对数,必须大于NN0LOG(,)返回以为底的对数n1n2MOD()返回除以的余数,n1n2POWER(,)返回的次方n1n2ROUND(,)返回舍入小数点右边位的的值,的缺省值为,这回将小数点最接近的整数,n2n1n20如果为负数就舍入到小数点左边相应的位上,必须是整数。

n2n2 select ROUND(12345,-2),ROUND(12345.54321,2) FROM dualROUND(12345,-2) ROUND(12345.54321,2)12300 12345.54SIGN()如果为负数,返回如果为正数,返回,如果返回n-1,n1n=00.(SIN)返回的正玄值为弧度。

n,nSINH()返回的双曲正玄值为弧度。

n,nSQRT()返回的平方根为弧度n,n(TAN)返回的正切值为弧度n,nTANH()返回的双曲正切值为弧度n,nTRUNC(,)返回截尾到位小数的的值,缺省设置为,当为缺省设置时会将截尾为n2n1n20n2n1整数,如果为负值,就截尾在小数点左边相应的位上。

相关文档
最新文档