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. 注意事项
- 类型一致性:所有元素必须是可相加的类型
- 浮点数精度:对于需要高精度的浮点数求和,使用 math.fsum()
- 内存使用:对于极大数据集,使用生成器而不是列表
- 字符串处理:不要用 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开发的程序打包为...
- 一周热门
- 最近发表
-
- python创建文件夹,轻松搞定,喝咖啡去了
- 如何编写第一个Python程序_pycharm写第一个python程序
- Python文件怎么打包为exe程序?_python3.8打包成exe文件
- 官方的Python环境_python环境版本
- [编程基础] Python配置文件读取库ConfigParser总结
- Python打包exe软件,用这个库真的很容易
- 2025 PyInstaller 打包说明(中文指南),python 打包成exe 都在这里
- Python自动化办公应用学习笔记40—文件路径2
- Python内置tempfile模块: 生成临时文件和目录详解
- python代码实现读取文件并生成韦恩图
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)