函数形态
Python 函数形态一般如下所示:
import jsondef main_handler(event, context):print("Received event: " + json.dumps(event, indent = 2))print("Received context: " + str(context))return("Hello World")
执行方法
在创建 SCF 云函数时,均需要指定执行方法。使用 Python 开发语言时,执行方法类似
index.main_handler
,此处 index
表示执行的入口文件为 index.py
,main_handler
表示执行的入口函数为 main_handler
函数。在使用本地 zip 文件上传、COS 上传等方法提交代码 zip 包时,请确认 zip 包的根目录下包含有指定的入口文件,文件内有定义指定的入口函数,文件名和函数名和执行方法处填写的能够对应,避免因为无法查找到入口文件和入口函数导致的执行失败。入参
Python 环境下的入参包括 event 和 context,两者均为 Python dict 类型。
event:使用此参数传递触发事件数据。
context:使用此参数向您的处理程序传递运行时信息。
返回
您的处理程序可以使用
return
来返回值,根据调用函数时的调用类型不同,返回值会有不同的处理方式。在 Python 环境下,您可以直接返回一个可序列化的对象。例如,返回一个
dict
对象:def main_handler(event, context):resp = {"isBase64Encoded": False,"statusCode": 200,"headers": {"Content-Type":"text/html","Key":["value1","value2","value3"]},"body": "<html><body><h1>Heading</h1><p>Paragraph.</p></body></html>"}return(resp)
返回值不同处理方式:
同步调用:使用同步调用时,返回值序列化后以 JSON 的格式返回给调用方,调用方可以获取返回值已进行后续处理。例如通过控制台进行函数调试的调用方法就是同步调用,能够在调用完成后捕捉到函数返回值并显示。
异步调用:异步调用时,由于调用方法仅触发函数就返回,不会等待函数完成执行,因此函数返回值会被丢弃。
说明
无论同步调用还是异步调用,返回值均会在函数的日志中记录。
异常处理
您可以在函数内通过使用
raise Exception
的方式抛出异常。如果您在返回前捕捉并处理异常,未继续向外抛出时,函数将认为是成功执行并正常返回入口函数中
return
指定的信息。
在如下示例代码中,函数执行成功,则返回值为 Hello World
。# -*- coding: utf8 -*-def main_handler(event, context):try:print("try exception")raise Exception("err msg")except Exception as e:print(e)return("Hello World")
如果在返回前未捕捉异常,异常将会抛出到入口函数之外并由函数平台捕捉。此时函数将认为是执行失败,函数返回信息替换为执行失败信息。
在如下示例代码中,函数执行失败。
# -*- coding: utf8 -*-def main_handler(event, context):print("try exception")raise Exception("err msg")return("Hello World")
函数返回信息如下:
{"errorCode":-1,"errorMessage":"user code exception caught","requestId":"a325b967-ef5b-4aa3-a329-c6bb0df72948","stackTrace":"Traceback (most recent call last):\\n File \\"/var/user/index.py\\", line 4, in main_handler\\n raise Exception(\\"err msg\\")\\nException: err msg","statusCode":430}
其中
errorCode
字段标识错误为代码错误,errorMessage
字段标识错误具体说明,stackTrace
字段输出错误堆栈信息,statusCode
字段标识具体错误。statusCode
具体说明请参见 云函数状态码。