首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Python 函数为什么会默认返回 None

它们的执行效果跟直接写 return 语句相比,是完全相同的: 这 4 个例子属于两种类型:一种没有写 return,但是都有隐藏的 return 返回值;一种写了 return,而且实际也有返回值。...不管有没有写 return,它们都会执行 return 的逻辑,而且默认的返回值就是 None。 那么,问题来了:Python 的函数为什么能默认返回 None 呢?它是如何实现的呢?...答案就在解释器中,当 CPython 解释器执行到函数的最后一个代码块时,若发现没有返回值,它就会主动地加上一个 Py_None返回(出自:compile.c): 也就是说,如果定义的函数没有返回值...,Python 解释器就会(强行地)默认给我们注入一段返回逻辑!...那么,这就会引出新的问题:Python 为什么要求函数都要有返回值呢?为什么它不像某些语言那样,提供一个 void 关键字,支持定义无返回值的空函数呢?

2.1K40

四、网页信息存储和 BeautifulSoupfind用法

网页信息存储和 BeautifulSoupfind用法 前言 一、BeautifulSoupfind用法 find find_all 具体使用示例 二、网页信息存储 1.基础知识...2.写入数据 感谢 ---- 前言 在这一章会解决上一章结尾问题BeautifulSoupfind用法,并进入爬虫的第三个流程,信息存储。...---- 一、BeautifulSoupfind用法 BeautifulSoupfindfind_all的方法。但在使用之前一定要先建立一个beautifulsoup对象。...find返回第一个匹配到的对象 语法: find(name, attrs, recursive, text, **wargs)  name–查找标签 text–查找文本 attrs–基于attrs...参数 find_all 返回所有匹配到的结果,区别于findfind返回查找到的第一个结果) 语法: find_all(name, attrs, recursive, text, limit, *

40710

Python学习日记5|BeautifulSoupfindfind_all的用法

在爬取网页中有用的信息时,通常是对存在于网页中的文本或各种不同标签的属性值进行查找,Beautiful Soup中内置了一些查找方式,最常用的是find()和find_all()函数。...同时通过soup.find_all()得到的所有符合条件的结果和soup.select()一样都是列表list,而soup.find()只返回第一个符合条件的结果,所以soup.find()后面可以直接接...('ul') ,那么返回结果是第一个ul标签以及......二、find_all()用法 应用到find()中的不同过滤参数同理可以用到find_all()中,相比find(),find_all()有个额外的参数limit,如下所示: p=soup.find_all...(text='algae',limit=2) 实际上find()也就是当limit=1时的find_all()。

6.9K31

Could not find codec parameters for stream 0 (Video: h264, none)

Could not find codec parameters for stream 0 (Video: h264, none)在使用视频处理工具或者播放器时,有时我们可能会遇到错误信息 "Could...not find codec parameters for stream 0 (Video: h264, none)"。...总结当遇到错误信息 "Could not find codec parameters for stream 0 (Video: h264, none)"时,我们应该先检查播放器或视频处理工具的版本,并确保安装了相应的解码器...希望本文能够帮助你解决 "Could not find codec parameters for stream 0 (Video: h264, none)" 的错误,并让你能够正常播放视频文件。...当遇到错误信息 "Could not find codec parameters for stream 0 (Video: h264, none)" 时,我们可以通过检查视频文件格式,并转码视频格式的方式来解决问题

71710

python递归调用中的坑:打印有值, 返回None

今天给大家分享小编遇到的一个坑有关python递归调用中的坑:打印有值, 返回None问题。...return right_shift(s, n) s = right_shift(s1, 4) print(s) # 成功输出 "efgabcd" 知识点补充:python 递归返回None 解决 今天写了一个递归...return 之前答应出来都是有值的, 调用时候返回值都是None ,很是纳闷 后来找到原因 现在来看下返回None 的代码 def get_end_parent_ele(self, obj):...def get_end_parent_ele(self, obj): """获取这个id 所在的原始""" parent_id = obj.parent_id if obj else...None 总结 到此这篇关于python递归调用中的坑:打印有值, 返回None的文章就介绍到这了,更多相关python递归打印有值返回none内容请搜索ZaLou.Cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持

2.4K31

【Python】函数 ④ ( 函数 None 返回值 | None 值应用场景 | 用于 if 判断 | 定义无初始内容变量 | 代码示例 )

# 函数体 # return 返回值 (可选) Python 函数中没有显示定义返回值 , 那么返回的就是 特殊字面量 None , 其类型是 ; None...- 接收 None 返回值 下面的代码中 , hello 函数没有使用 return 关键字 返回 返回值 ; 该 hello 函数 没有显示定义 返回值 , 实际上该函数返回的是 None 返回值...; 使用变量接收该函数的返回值 , 返回值是 None , 返回值类型是 NoneType ; 代码示例 : """ 接收 函数 None 返回值示例 """ # 定义无返回值的函数 def hello...return 关键字返回 None 在该示例中 , 比上一个示例多了 return None 返回值 , 其执行效果与没有返回值一模一样 ; 代码示例 : """ 接收 函数 None 返回值示例 ""...None 二、None 值应用场景 ---- 1、None 值应用场景简介 函数 None 返回值应用场景 : 函数返回值 : 表示函数没有返回值 ; 用于 if

31920

六、解析库之Beautifulsoup模块

,如果只有一个子节点那么就输出该子节点的文本,比如下面的这种结构,soup.p.string 返回None,但soup.p.strings就可以找到所有文本 哈哈哈哈...')) #查找为sister的a标签 print(soup.find_all('a',class_='sister ssss')) #查找为sister和sss的a标签,顺序错误也匹配不成功 print...(soup.find_all(class_=re.compile('^sis'))) #查找为sister的所有标签 #2.4、attrs print(soup.find_all('p',attrs...('title') # The Dormouse's story 唯一的区别是 find_all() 方法的返回结果是值包含一个元素的列表,而 find() 方法直接返回结果.... find_all() 方法没有找到目标是返回空列表, find() 方法找不到目标时,返回 None . print(soup.find("nosuchtag")) # None soup.head.title

1.6K60

​Python爬虫-BeautifulSoup详解

None print(soup.html.string) # 输出:None 那么当前 tag下有多个标签,如果返回内容呢?...如果节点不存在,返回 None # p节点的下一个兄弟节点的上一个兄弟节点,等于p 本身 print(soup.body.p.next_sibling.previous_sibling.string)...关键字 # 只输出两个 a 标签即可 soup.find_all(name='a', limit=2) (2)find:搜索所有子节点,返回结果 find_all 返回所有子节点,且返回列表 find...css选择器 我们在写 CSS 时,标签名不加任何修饰,名前加点,id名前加 # 在这里我们也可以利用类似的方法来筛选元素,用到的方法是 soup.select(),返回类型是 list (1)通过标签名查找...查找所有找到的结果,返回 list # 查找title标签 print(soup.select('title')) # 查找 a 标签 print(soup.select('a')) (2)通过名查找

1.5K30

Python爬虫学习笔记之爬虫基础库

兄弟节点可以理解为和本节点处在统一级的节点,.next_sibling 属性获取了该节点的下一个兄弟节点,.previous_sibling 则与之相反,如果节点不存在,则返回 None 在文档树中,...>The Dormouse's story 唯一的区别是 find_all() 方法的返回结果是值包含一个元素的列表,而 find() 方法直接返回结果. find_all() 方法没有找到目标是返回空列表..., find() 方法找不到目标时,返回 None . print(soup.find("nosuchtag")) # None soup.head.title 是 tag的名字 方法的简写.这个简写的原理就是多次调用当前... 属性对当tag的所有后面解析的兄弟tag节点进行迭代, find_next_siblings() 方法返回所有符合条件的后面的兄弟节点, find_next_sibling() 只返回符合条件的后面的第一个...回到顶部 beautifulsoup的css选择器 我们在写 CSS 时,标签名不加任何修饰,名前加点,id名前加 #,在这里我们也可以利用类似的方法来筛选元素,用到的方法是 soup.select(

1.8K20
领券