这是代码:
def url_is_image(url): if url[-4:] in ['.jpg', '.png']: return True elif 'imgur' in url: url += '.jpg' return True else: return False u1 = 'http://i.imgur.com/jtboy' url_is_image(u1) print u1
输出为' http://i.imgur.com/jtboy ',没有.jpg扩展名.为什么我的函数(第5行)无法将.jpg添加到字符串的任何想法?谢谢
参数的范围url
是函数调用的本地范围.对它的赋值不会影响函数外的任何变量或值.
该变量u1
被分配给一次.函数调用不会影响它.然后打印出来.
既然你没有测试函数返回值的真实性,你可以这样重写它:
def url_is_image(url): if url[-4:] in ['.jpg', '.png']: return url elif 'imgur' in url: return url + '.jpg' else: return url u1 = 'http://i.imgur.com/jtboy' u1 = url_is_image(u1) print u1
但是,在这种情况下,函数名称会产生误导.由于我不知道您希望如何真正使用该功能,因此很难提出更好的解决方案.也许你想要返回一个包含布尔值和修改后的字符串的2元组.
附录:基于您在评论中概述的目的,我会考虑一个只返回有趣URL的函数.例如:
def consider_url(url): if url[-4:] in ['.jpg', '.png']: return url elif 'imgur' in url: return url + '.jpg' else: return None
然后你可以使用它来转换有趣的URL并忽略不感兴趣的URL.
for url in some_list: url = consider_url(url) if url is None: continue print(url)
另一种方法是编写一个只为您提供有趣网址的生成器:
def interesting_urls(iter): for url in iter: if url[-4:] in ['.jpg', '.png']: yield url elif 'imgur' in url: yield url + '.jpg'
然后,您可以更简洁地处理您的网址:
for url in interesting_urls(some_list): print(url)
这些示例假设您已经以某种方式检索了列表或其他可迭代对象中的URL.您可以使用以下简单列表进行尝试.虽然列表中的大多数字符串都不是有效的URL,但它们确实运用了上述函数的逻辑.
some_list = [ "foo", "bar.jpg", "something/imgur/baz", "uninteresting", 'http://i.imgur.com/jtboy' ]