python list去重

list(set(args.core)) 是一种在 Python 中快速去除列表中重复元素的简洁方法。让我详细解释这个操作的实现原理和工作流程:

完整代码解析

python 复制代码
# 原始列表(可能包含重复元素)
cores = ['bl', 'ap', 'sensor', 'ap', 'bl']

# 步骤1: 使用 set() 创建集合
unique_set = set(cores)  # 结果: {'sensor', 'bl', 'ap'}

# 步骤2: 将集合转换回列表
unique_list = list(unique_set)  # 结果: ['sensor', 'bl', 'ap']

# 最终结果
print(unique_list)  # 输出: ['sensor', 'bl', 'ap'](顺序可能不同)

详细步骤说明

1. set(args.core) - 创建集合

  • 集合特性 :Python 的集合(set)是一种无序且元素唯一的数据结构

  • 去重原理:当将列表转换为集合时,所有重复元素会被自动移除

  • 示例

    python 复制代码
    >>> set(['a', 'b', 'a', 'c'])
    {'c', 'a', 'b'}  # 去除了重复的 'a'

2. list(...) - 转换回列表

  • 目的:将去重后的集合转换回列表类型

  • 注意:由于集合是无序的,转换后的列表顺序可能与原列表不同

  • 示例

    python 复制代码
    >>> list({'c', 'a', 'b'})
    ['c', 'a', 'b']  # 顺序可能每次运行都不同

为什么使用这种方法去重?

  1. 简洁高效:一行代码完成去重操作
  2. 时间复杂度:O(n) - 对于大多数情况都非常高效
  3. 代码可读性:清晰表达"我需要去重"的意图

保持顺序的去重方法

如果您需要保持元素的原始顺序,可以使用以下方法:

python 复制代码
def unique_ordered(items):
    seen = set()
    unique = []
    for item in items:
        if item not in seen:
            seen.add(item)
            unique.append(item)
    return unique

# 使用示例
cores = ['bl', 'ap', 'sensor', 'ap', 'bl']
unique_cores = unique_ordered(cores)  # 结果: ['bl', 'ap', 'sensor']

在您的脚本中的应用

在您的烧录脚本中,使用 list(set(args.core)) 是合适的,因为:

  1. 核心顺序不重要:烧录顺序由脚本逻辑控制,不是由用户输入顺序决定
  2. 高效去重:避免用户重复指定同一核心
  3. 代码简洁:一行代码完成去重,保持代码简洁

完整脚本中的去重逻辑

python 复制代码
# 处理核心列表
if 'all' in args.core:
    cores = SUPPORTED_CORES.copy()
else:
    # 去重处理
    cores = list(set(args.core))  # 去除重复的核心名称
    
    # 验证核心是否有效
    invalid_cores = [core for core in cores if core not in SUPPORTED_CORES]
    if invalid_cores:
        print(f"错误: 不支持的核心: {', '.join(invalid_cores)}")
        print(f"有效核心: {', '.join(SUPPORTED_CORES)}")
        sys.exit(1)

实际应用示例

用户输入重复核心

bash 复制代码
./flash_p62.py -c bl ap bl sensor -p 0 -t ACM -d nx

处理后的核心列表

python 复制代码
# 输入: args.core = ['bl', 'ap', 'bl', 'sensor']
cores = list(set(['bl', 'ap', 'bl', 'sensor'])) 
# 结果: ['sensor', 'bl', 'ap'] (顺序可能不同)

最终烧录的核心

脚本会烧录 sensor, bl 和 ap 核心,但只烧录一次,不会重复烧录 bl

注意事项

  1. 顺序不可控:集合是无序的,所以结果列表的顺序可能与输入不同
  2. 仅适用于可哈希类型:集合要求元素必须是可哈希的(字符串、数字等)
  3. 不适合自定义对象 :如果是自定义对象,需要实现 __hash____eq__ 方法

在您的烧录脚本中,由于核心名称都是字符串,这种去重方法是最佳选择,既高效又简洁。

相关推荐
IVEN_5 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang7 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮7 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling7 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮10 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽10 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健1 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞1 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽1 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers