python函数返回空 python 返回空值

用python中re.match匹配为什么一直是None?re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none 。
re.search 扫描整个字符串并返回第一个成功的匹配 。
re.findall 在字符串中找到正则表达式所匹配的所有子串,并返回一个列表 , 如果没有找到匹配的,则返回空列表 。
所以如果你要匹配的字符不是在字符串的起始位置,应该用search函数,
如果你要返回字符串中所有的匹配,应该用findall函数,因为match和search都匹配一次.
所以你的程序应该这么写
import re
print(re.search('/(index|view)/','/places/default/user/register?_next=/places/default/view/1').group(0))
python中的函数必须明确指出返回类型python没有静态类型 , 因此不需要也不可以指定函数的返回类型 。
依据业务逻辑的需要,一个函数可以返回任何值,也可以什么都不返回 。
比如:
def f1():return 1
def f2():return 'ok'
def f3():return [1,2,'good']
求帮助,Python闭包和返回函数问题(1)unpack tuple和list, 可以让函数返回多个值
def count():
return (1, 2, 3) # 或者 return [1, 2, 3]
# 把列表解包,把1 2 3 分别赋值给 a b c
a, b, c = count()
print a, b, c
# 输出 1, 2, 3
(2)假设你知道Python的dict类型 。Python中,在函数中定义一个变量的时候,会在一个隐藏的叫locals的dict里面插入key-value,其中key是变量名,value是变量值 。而引用一个变量的时候 , 则首先会在这个叫locals的dict里面,根据变量名作为key,去查对应的值 。
var = 1# 你可以认为这里进行了 locals['var'] = 1 的操作
print var# 在对var变量进行求值的时候,就在locals['var']里面找var变量对应的值
(3)for循环中 , 每次循环只是给 `i` 重新绑定值
for i in (1, 2, 3):
print i
print i
# 一次输入 1 2 3 3
每次`for i in (1, 2, 3)`相当于在`print i`之前,进行了
`locals['i'] = 1`
`locals['i'] = 2`
`locals['i'] = 3`
的操作
所以最后的`print i`再去locals字典里面找`i`的时候 , 就变成 3 了 。
(4)闭包是 一个函数加上这个函数引用的外部变量
var = 1
def f():
print var
# 这里的闭包是函数 f 和 f 引用的外部变量 var
def count():
var2 = 2
def f():
print var2
# 这里的闭包是函数 f 和 f 引用的外部变量 var2
return f
拿第一个函数 f 来说 。在 f 运行的时候,解释器拿着'var'这个字符串去locals字典里面找,发现找不到 , 于是在closure字典里面找 , 最后closure字典里面找,你可以认为就是找closure['var'],然后发现找到对应的值 。count里面的 f 函数同理 。
(为了容易理解,我这里说谎了 。实际上 f 压根没有closure,count里面的 f 才有 。其实closure压根不是像locals那样的字典)
(5)函数定义时 , 函数只是记录变量的名字 。
要区分什么是名字 , 什么是值 。
`i = 1`这里 i 只是名字 , 只是一个字符串 'i'。这句话运行完,locals['i'] = 1,就说 i 对应的值是1
def count():
fs = []
for i in range(1, 4):
# 定义一个函数,等价于运行了 locals['f'] = 真正生成的函数
# 每次循环,这里都会重新生成一个函数,然后把重新生成的函数赋值给 locals['f']
def f():
return i * i# 引用了'i'这个名字,但并不是引用了'i'对应的值
# 等价于 locals['fs'].append(locals['f'])
# f 不是函数,它只是一个名字'f' 。f 引用的东西,也就是locals['f']才是真正的函数

推荐阅读