百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python 3 基础教程 - 函数(python函数csdn)

off999 2024-10-18 08:00 31 浏览 0 评论


函数是一组有组织的、可重用的代码,用于执行单个相关操作。函数为应用程序提供更好的模块化和高度的代码重用。Python 提供了许多内置函数,如 print() 等。也可以创建自己的函数。这些函数称为用户定义函数。

定义函数

可以定义函数以提供所需的功能。以下是在 Python 中定义函数的简单规则。

  • 函数块以关键字def开头,后跟函数名称和圆括号 ( ( ) )。
  • 任何输入参数或自变量都应放在这些括号内。您还可以在这些括号内定义参数。
  • 函数的第一条语句可以是可选语句——函数的文档字符串或文档字符串
  • 每个函数中的代码块都以冒号 (:) 开头并缩进。
  • 语句 return [expression] 退出函数,可选择将表达式返回给调用者。没有参数的 return 语句与 return None 相同。

语法

def functionname( parameters ):   #函数名和参数
   ...   #具体代码
   return [expression]   #函数返回值

例如,定义一个打印函数,将输入的内容打印在显示器上。没有返回值。

def printer( str ):
   print (str)
   return

调用函数

定义一个函数只给了函数一个名称,指定了函数里包含的参数,和代码块结构。

这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从Python提示符执行。例如,调用上面定义的函数printer()。

def printer( str ):
   print (str)
   return

printer("打印一行内容!")   # 调用函数printer()
#运行结果
打印一行内容!

参数传递

在 python 中,类型属于对象,变量是没有类型的。

可更改(mutable)与不可更改(immutable)对象

在 python 中,strings, tuples, 和 numbers 是不可更改的对象,而 list,dict 等则是可以修改的对象。

  • 不可变类型:变量赋值 a=5 后再赋值 a=10,这里实际是新生成一个 int 值对象 10,再让 a 指向它,而 5 被丢弃,不是改变a的值,相当于新生成了a。
  • 可变类型:变量赋值 la=[1,2,3,4] 后再赋值 la[2]=5 则是将 list la 的第三个元素值更改,本身la没有动,只是其内部的一部分值被修改了。

python 函数的参数传递:

  • 不可变类型:类似 c++ 的值传递,如 整数、字符串、元组。如fun(a),传递的只是a的值,没有影响a对象本身。比如在 fun(a)内部修改 a 的值,只是修改另一个复制的对象,不会影响 a 本身。
  • 可变类型:类似 c++ 的引用传递,如 列表,字典。如 fun(la),则是将 la 真正的传过去,修改后fun外部的la也会受影响

python 中一切都是对象,严格意义不能说值传递还是引用传递,而应该说传不可变对象和传可变对象。

传递不可变对象时,函数内外参数是互不影响的。

def add(x,y):
    x = x + 1
    y = y * 2
    print("x:", x, '    ','y:',y)
    return x + y

a = 3
b = 5
c = add(a,b)
print('c:',c)
print("a:", a, '    ','b:',b)

运行结果

x: 4      y: 10
c: 14
a: 3      b: 5
#说明是互不影响的

传递可变对象时,函数内外参数是相互影响的。

def updatelist(list):
   list[1] = 5 
   print ("inside the function: ", list)
   return

#调用函数
list = [10,20,30]
updatelist( list )
print ("outside the function: ", list)

运行结果

inside the function:  [10, 5, 30]
outside the function:  [10, 5, 30]
#内外部结果同时发生变化。

参数

以下是调用函数时可使用的参数类型:

  • 必备参数
  • 关键字参数
  • 默认参数
  • 不定长参数

必备参数

必备参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。例如调用上面定义的add()函数,必须传入两个参数,不然会出现语法错误:

c = add(a)
print('c:',c)
#运行结果
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
Cell In [68], line 1
----> 1 c = add(a)
      2 print('c:',c)

TypeError: add() missing 1 required positional argument: 'y'

关键字参数

关键字参数与函数调用有关。在函数调用中使用关键字参数时,调用者通过参数名称识别参数。这允许跳过参数或乱序放置它们,因为 Python 解释器能够使用提供的关键字将值与参数匹配。例如:

def add(x,y):
    x = x + 1
    y = y * 2
    return x + y

a = 3
b = 5
c = add(y=b, x=a)
print('c:',c)
#运行结果
14

默认参数

默认参数是在函数调用中未为该参数提供值时采用默认值的参数。例如:

def add(x, y = 3):
    x = x + 1
    y = y * 2
    return x + y

c = add(5,5)
d = add(x=5)
print('c:',c)
print('d:',d)
#运行结果
c: 16
d: 12

不定长参数

有时可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。基本语法如下:

def functionname([formal_args,] *var_args_tuple ):
   ...
   return [expression]
# 可写函数说明
def printinfo( arg1, *vartuple ):
   "打印任何传入的参数"
   print "输出: "
   print arg1
   for var in vartuple:
      print var
   return
 
# 调用printinfo 函数
printinfo( 10 )
printinfo( 70, 60, 50 )
输出:
10
输出:
70
60
50

return 语句

return语句[表达式]退出函数,选择性地向调用方返回一个表达式。不带参数值的return语句返回None。

def add(x, y):
    return x + y

c = add(5,5)
print('c:',c)

变量作用域

一个程序的所有的变量并不是在哪个位置都可以访问的。访问权限决定于这个变量是在哪里赋值的。

变量的作用域决定了在哪一部分程序可以访问哪个特定的变量名称。两种最基本的变量作用域如下:

  • 全局变量
  • 局部变量

定义在函数内部的变量拥有一个局部作用域,定义在函数外的拥有全局作用域。

局部变量只能在其被声明的函数内部访问,而全局变量可以在整个程序范围内访问。调用函数时,所有在函数内声明的变量名称都将被加入到作用域中。

total = 5 # 这是一个全局变量
def add( x, y ):
   total = x + y # total在这里是局部变量.
   print("局部变量 total: ", total )
   return total
 
#调用函数
add( 10, 10 )
print("全局变量 total: ", total )
#运行结果
局部变量 total:  20
全局变量 total:  5

相关推荐

Linux 网络协议栈_linux网络协议栈

前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...

揭秘 BPF map 前生今世_bpfdm

1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...

教你简单 提取fmpeg 视频,音频,字幕 方法

ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...

Linux内核原理到代码详解《内核视频教程》

Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...

Linux C Socket UDP编程详解及实例分享

1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...

libevent源码分析之bufferevent使用详解

libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...

一次解决Linux内核内存泄漏实战全过程

什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...

彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏

作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...

linux网络编程常见API详解_linux网络编程视频教程

Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...

Linux下C++访问web—使用libcurl库调用http接口发送解析json数据

一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...

平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道

在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...

谈谈分布式文件系统下的本地缓存_什么是分布式文件存储

在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...

进程间通信之信号量semaphore--linux内核剖析

什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...

Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门

一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...

30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南

30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...

取消回复欢迎 发表评论: