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__ 方法

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

相关推荐
JovaZou13 分钟前
[Python学习日记-92] 并发编程之多线程 —— 守护线程
开发语言·python·学习
叶 落2 小时前
三种语言写 MCP
java·python·ai·typescript·mcp
狐凄7 小时前
Python实例题:基于边缘计算的智能物联网系统
python·物联网·边缘计算
@十八子德月生7 小时前
第十章——8天Python从入门到精通【itheima】-99~101-Python基础综合案例-数据可视化(案例介绍=JSON格式+pyecharts简介)
大数据·python·信息可视化·pycharm·echarts·数据可视化
W说编程7 小时前
算法导论第二十四章 深度学习前沿:从序列建模到创造式AI
c语言·人工智能·python·深度学习·算法·性能优化
动能小子ohhh8 小时前
html实现登录与注册功能案例(不写死且只使用js)
开发语言·前端·javascript·python·html
Blue桃之夭夭8 小时前
Python爬虫(六):Scrapy框架
爬虫·python·scrapy
大模型铲屎官8 小时前
【深度学习-Day 31】CNN基石:彻底搞懂卷积层 (Convolutional Layer) 的工作原理
人工智能·pytorch·python·深度学习·机器学习·cnn·llm
struggle20259 小时前
DeepForest开源程序是用于 Airborne RGB 机器学习的 Python 软件包
开发语言·python