时间:2021-05-22
基于Python中求和函数sum的用法详解
今天在看《集体编程智慧》这本书的时候,看到一段Python代码,当时是百思不得其解,总觉得是书中排版出错了,后来去了解了一下sum的用法,看了一些Python大神写的代码后才发现是自己浅薄了!特在此记录一下。书中代码段摘录如下:
from math import sqrtdef sim_distance(prefs, person1, person2): # 得到shared_items的列表 si = {} for item in prefs[person1]: if item in prefs[person2]: si[item] = 1 # 如果两者没有共同之处,则返回0 if len(si) == 0: return 0 # 计算所有差值的平方和 sum_of_squares = sum([pow(prefs[person1][item] - prefs[person2][item], 2) for item in prefs[person1] if item in prefs[person2]]) return 1/(1 + sqrt(sum_of_squares))自己不明白的代码块就是在计算所有差值的平方和这里,按照一般语言逻辑,应该是for语句和pow语句位置对调一下啊,很是困惑!后来查阅了一下sum函数的用法才豁然开朗,再次感叹Python之神(bian)奇(tai)语法。
sum函数的参数是这样的:sum(iterable[, start]),其中iterable为可迭代对象,可以是list、tuple或者dictionary等。
sum函数最后的值 = 可迭代对象里面的数相加的值 + start的值,其中start可以不写,默认为0。讲到这里,那么我们怎么去理解上面计算所有差值的平方和这段代码呢?其实很简单,看看下面这段代码,然后再回去看上面那段代码就会柳暗花明了!
from math import sqrta = range(1, 11)b = range(1, 10)c = sum([item for item in a if item in b])print c可以自己输入这段简单的代码运行试试,最终的结果是:45
补充一点:"item for item in a if item in b" 这种表达式叫作列表推导式,是在一组字符串或者一组对象上执行一条相同操作的简洁写法!
以上这篇基于Python中求和函数sum的用法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.列表使用sum,如下代码,对1维列表和二维列表,numpy.sum(a)都能将列表a中的所有元素求和并返回,a.sum()用法是非法的。但是对于1维列表,s
sum公式使用方法: 1、打开需要使用sum函数的Excel表格; 2、单击菜单栏上的“公式”键,找求和公式; 3、单击公式中的“插入函数”,选择要插入的
excel包括的函数如下: 1、求和函数SUM,求和函数是里边非常简单的函数,它是一个数学和三角函数,可将值进行相加。 2、条件求和函数SUMIF,条件求和
在Excel的使用中,有时需要用到Sum函数来进行数值求和,那么在Excel中如何使用Sum函数?下面为大家详细介绍一下,一起来看看吧! 方法/步骤 1
Python中可以使用for循环实现累加求和for循环语法:for变量inrange(x):循环需要执行的代码如下实现1到n求和:defmain():sum=0