百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

python常用得内置函数解析——sum()函数

itomcoil 2025-10-02 20:41 15 浏览

道友我们来详细解析 Python 中非常实用的内置函数 sum()。

1. 函数定义

sum() 函数用于计算可迭代对象中所有元素的总和。

  • 语法:sum(iterable, /, start=0)
  • 参数
    • iterable:必需,要计算总和的可迭代对象(列表、元组、集合等)
    • start:可选,起始值,会加到总和上(默认为 0)
  • 返回值:所有元素的总和加上 start 值

2. 基本用法示例

数字列表求和

# 整数列表
numbers = [1, 2, 3, 4, 5]
result = sum(numbers)
print(result)  # 输出: 15

# 浮点数列表
floats = [1.5, 2.5, 3.5]
result = sum(floats)
print(result)  # 输出: 7.5

# 混合数字类型
mixed = [1, 2.5, 3, 4.5]
result = sum(mixed)
print(result)  # 输出: 11.0 (自动提升为浮点数)

使用 start 参数

numbers = [1, 2, 3, 4]

# 默认 start=0
print(sum(numbers))        # 输出: 10

# 设置 start=5
print(sum(numbers, 5))     # 输出: 15 (10 + 5)

# 设置 start=10
print(sum(numbers, 10))    # 输出: 20 (10 + 10)

# 负数的 start
print(sum(numbers, -5))    # 输出: 5 (10 - 5)

其他可迭代对象

# 元组
tuple_nums = (1, 2, 3, 4)
print(sum(tuple_nums))     # 输出: 10

# 集合
set_nums = {1, 2, 3, 4}
print(sum(set_nums))       # 输出: 10

# 范围对象
range_obj = range(1, 6)    # 1, 2, 3, 4, 5
print(sum(range_obj))      # 输出: 15

# 生成器表达式
gen_expr = (x for x in range(1, 6))
print(sum(gen_expr))       # 输出: 15

3. 高级用法和技巧

字符串连接(需要配合 start 参数)

# 错误的用法:不能直接对字符串列表使用 sum()
strings = ['a', 'b', 'c']
# print(sum(strings))  # TypeError: unsupported operand type(s) for +: 'int' and 'str'

# 正确的用法:使用空字符串作为 start
result = sum(strings, '')  # 相当于 '' + 'a' + 'b' + 'c'
print(result)  # 输出: 'abc'

# 更推荐的做法:使用 join()
result = ''.join(strings)
print(result)  # 输出: 'abc'

列表合并

lists = [[1, 2], [3, 4], [5, 6]]
# 错误的用法
# print(sum(lists))  # TypeError

# 正确的用法:使用空列表作为 start
result = sum(lists, [])
print(result)  # 输出: [1, 2, 3, 4, 5, 6]

# 更推荐的做法:使用列表推导式或 itertools.chain()
import itertools
result = list(itertools.chain.from_iterable(lists))
print(result)  # 输出: [1, 2, 3, 4, 5, 6]

自定义对象的求和

class Product:
    def __init__(self, name, price):
        self.name = name
        self.price = price
    
    def __add__(self, other):
        if isinstance(other, Product):
            return self.price + other.price
        return self.price + other
    
    def __radd__(self, other):
        return other + self.price

products = [Product("Apple", 2.5), Product("Banana", 1.8), Product("Orange", 3.2)]

# 使用 sum() 计算总价
total_price = sum(products, 0)
print(f"总价: ${total_price}")  # 输出: 总价: $7.5

# 或者使用生成器表达式
total_price = sum(p.price for p in products)
print(f"总价: ${total_price}")  # 输出: 总价: $7.5

4. 实际应用场景

场景1:统计数据分析

# 计算平均值
scores = [85, 92, 78, 90, 88]
total = sum(scores)
average = total / len(scores)
print(f"总分: {total}, 平均分: {average:.2f}")  # 输出: 总分: 433, 平均分: 86.60

# 计算加权平均
weights = [0.2, 0.3, 0.5]
values = [80, 90, 85]
weighted_avg = sum(w * v for w, v in zip(weights, values))
print(f"加权平均: {weighted_avg:.2f}")  # 输出: 加权平均: 85.50

场景2:财务计算

# 计算多个交易的总和
transactions = [100, -50, 75, -30, 200]
balance = sum(transactions)
print(f"最终余额: ${balance}")  # 输出: 最终余额: $295

# 计算累计收益
investments = [1000, 500, 750]
returns = [0.05, 0.08, 0.06]  # 收益率

total_return = sum(inv * ret for inv, ret in zip(investments, returns))
print(f"总收益: ${total_return:.2f}")  # 输出: 总收益: $137.00

场景3:数据处理和聚合

# 从字典列表中提取并求和
sales_data = [
    {'product': 'A', 'sales': 100},
    {'product': 'B', 'sales': 200},
    {'product': 'C', 'sales': 150}
]

total_sales = sum(item['sales'] for item in sales_data)
print(f"总销售额: {total_sales}")  # 输出: 总销售额: 450

# 使用 map() 函数
total_sales = sum(map(lambda x: x['sales'], sales_data))
print(f"总销售额: {total_sales}")  # 输出: 总销售额: 450

5. 性能考虑和最佳实践

与循环比较的性能

import timeit

# 测试数据
large_list = list(range(10000))

# 测试 sum() 性能
sum_time = timeit.timeit('sum(l)', globals=globals(), number=1000)

# 测试 for 循环性能
loop_time = timeit.timeit('''
total = 0
for num in l:
    total += num
''', globals=globals(), number=1000)

print(f"sum() 时间: {sum_time:.4f}秒")
print(f"for循环时间: {loop_time:.4f}秒")
# sum() 通常比手写循环更快,因为它是用C实现的

内存效率考虑

# 对于非常大的数据集,使用生成器而不是列表
def large_data_generator():
    for i in range(1000000):
        yield i

# 内存效率高的方式
total = sum(large_data_generator())
print(f"总和: {total}")  # 输出: 499999500000

# 内存效率低的方式(不要这样做)
# total = sum([i for i in range(1000000)])  # 会创建整个列表在内存中

6. 错误处理和边界情况

# 空可迭代对象
empty_list = []
print(sum(empty_list))        # 输出: 0
print(sum(empty_list, 10))    # 输出: 10

# 包含非数字元素
mixed = [1, 2, '3', 4]
try:
    print(sum(mixed))         # TypeError: unsupported operand type(s) for +: 'int' and 'str'
except TypeError as e:
    print(f"错误: {e}")

# 使用过滤来处理混合数据
mixed = [1, 2, '3', 4, 'abc', 5]
numbers_only = (x for x in mixed if isinstance(x, (int, float)))
print(sum(numbers_only))      # 输出: 12 (1+2+4+5)

7. 与相关函数的比较

函数

用途

返回值

特点

sum()

求和

数字

通用,支持各种可迭代对象

math.fsum()

精确浮点求和

float

更精确的浮点数求和

numpy.sum()

数组求和

多种

支持多维数组,功能更强大

statistics.mean()

计算平均值

float

专门用于计算平均值

import math
import numpy as np

# 浮点数精度问题
floats = [0.1] * 10

print(sum(floats))          # 输出: 0.9999999999999999 (精度问题)
print(math.fsum(floats))    # 输出: 1.0 (更精确)

# 使用 numpy
arr = np.array([1, 2, 3, 4, 5])
print(np.sum(arr))          # 输出: 15

8. 注意事项

  1. 类型一致性:所有元素必须是可相加的类型
  2. 浮点数精度:对于需要高精度的浮点数求和,使用 math.fsum()
  3. 内存使用:对于极大数据集,使用生成器而不是列表
  4. 字符串处理:不要用 sum() 来连接字符串,用 join()
# 不推荐的字符串连接方式
words = ['hello', ' ', 'world']
result = sum(words, '')  # 能工作,但效率低
print(result)  # 输出: 'hello world'

# 推荐的方式
result = ''.join(words)  # 更高效
print(result)  # 输出: 'hello world'

总结

特性

描述

功能

计算可迭代对象中所有元素的总和

语法

sum(iterable, start=0)

参数

可迭代对象和可选的起始值

返回值

所有元素的总和加上起始值

性能

高效(C语言实现),比手写循环快

适用场景

数值计算、数据分析、统计汇总

注意事项

类型一致性、浮点数精度、内存效率

sum() 是 Python 中最常用和最高效的内置函数之一,几乎在所有需要求和的场景中都会用到。掌握它的各种用法和最佳实践对于编写高效的 Python 代码非常重要。

相关推荐

python创建文件夹,轻松搞定,喝咖啡去了

最近经常在录视频课程,一个课程下面往往有许多小课,需要分多个文件夹来放视频、PPT和案例,这下可好了,一个一个手工创建,手酸了都做不完。别急,来段PYTHON代码,轻松搞定,喝咖啡去了!import...

如何编写第一个Python程序_pycharm写第一个python程序

一、第一个python程序[掌握]python:python解释器,将python代码解释成计算机认识的语言pycharm:IDE(集成开发环境),写代码的一个软件,集成了写代码,...

Python文件怎么打包为exe程序?_python3.8打包成exe文件

PyInstaller是一个Python应用程序打包工具,它可以将Python程序打包为单个独立可执行文件。要使用PyInstaller打包Python程序,需要在命令行中使用py...

官方的Python环境_python环境版本

Python是一种解释型编程开发语言,根据Python语法编写出来的程序,需要经过Python解释器来进行执行。打开Python官网(https://www.python.org),找到下载页面,选择...

[编程基础] Python配置文件读取库ConfigParser总结

PythonConfigParser教程显示了如何使用ConfigParser在Python中使用配置文件。文章目录1介绍1.1PythonConfigParser读取文件1.2Python...

Python打包exe软件,用这个库真的很容易

初学Python的人会觉得开发一个exe软件非常复杂,其实不然,从.py到.exe文件的过程很简单。你甚至可以在一天之内用Python开发一个能正常运行的exe软件,因为Python有专门exe打包库...

2025 PyInstaller 打包说明(中文指南),python 打包成exe 都在这里

点赞标记,明天就能用上这几个技巧!linux运维、shell、python、网络爬虫、数据采集等定定做,请私信。。。PyInstaller打包说明(中文指南)下面按准备→基本使用→常用...

Python自动化办公应用学习笔记40—文件路径2

4.特殊路径操作用户主目录·获取当前用户的主目录路径非常常用:frompathlibimportPathhome_dir=Path.home()#返回当前用户主目录的Path对象...

Python内置tempfile模块: 生成临时文件和目录详解

1.引言在Python开发中,临时文件和目录的创建和管理是一个常见的需求。Python提供了内置模块tempfile,用于生成临时文件和目录。本文将详细介绍tempfile模块的使用方法、原理及相关...

python代码实现读取文件并生成韦恩图

00、背景今天战略解码,有同学用韦恩图展示各个产品线的占比,效果不错。韦恩图(Venndiagram),是在集合论数学分支中,在不太严格的意义下用以表示集合的一种图解。它们用于展示在不同的事物群组之...

Python技术解放双手,一键搞定海量文件重命名,一周工作量秒搞定

摘要:想象一下,周五傍晚,办公室的同事们纷纷准备享受周末,而你,面对着堆积如山的文件,需要将它们的文件名从美国日期格式改为欧洲日期格式,这似乎注定了你将与加班为伍。但别担心,Python自动化办公来...

Python路径操作的一些基础方法_python路径文件

带你走进@机器人时代Discover点击上面蓝色文字,关注我们Python自动化操作文件避开不了路径操作方法,今天我们来学习一下路径操作的一些基础。Pathlib库模块提供的路径操作包括路径的...

Python爬取下载m3u8加密视频,原来这么简单

1.前言爬取视频的时候发现,现在的视频都是经过加密(m3u8),不再是mp4或者avi链接直接在网页显示,都是经过加密形成ts文件分段进行播放。今天就教大家如果通过python爬取下载m3u8加密视频...

探秘 shutil:Python 高级文件操作的得力助手

在Python的标准库中,shutil模块犹如一位技艺精湛的工匠,为我们处理文件和目录提供了一系列高级操作功能。无论是文件的复制、移动、删除,还是归档与解压缩,shutil都能以简洁高效的方式完成...

怎么把 Python + Flet 开发的程序,打包为 exe ?这个方法很简单!

前面用Python+Flet开发的“我的计算器v3”,怎么打包为exe文件呢?这样才能分发给他人,直接“双击”运行使用啊!今天我给大家分享一个简单的、可用的,把Flet开发的程序打包为...