0

0

如何使用 openpyxl 在 Excel 中根据 ID 精准查找对应用户名

花韻仙語

花韻仙語

发布时间:2026-02-09 11:21:35

|

165人浏览过

|

来源于php中文网

原创

如何使用 openpyxl 在 Excel 中根据 ID 精准查找对应用户名

本文介绍如何利用 openpyxl 高效、准确地在 excel 表格中根据唯一 id 值定位并获取同一行的用户名,避免全表遍历和列偏移错误,提升查找鲁棒性与可维护性。

在实际数据处理中,我们常需根据某列(如 ID)的值反向查找同行其他列(如 Username)的内容。但若采用全单元格遍历(iter_rows 覆盖全部行列)并依赖固定列偏移(如 cell.column - 9),极易因表头变动、空行或列顺序调整而失效——正如原代码中 cell.column - 9 的硬编码导致无法正确映射到 Username 列(实际应为 ID 列左侧第 2 列,即 C → A)。

推荐做法:明确指定目标列,按列精准搜索
根据示例数据结构:

A (Username) B (Lastseen) C (ID) D (IDandsomething)
Bob 555533aa http555533aa
Mary 1 y ago 3993fj3a http3993fj3a
Joe 1 d ago u7783ifd httpu7783ifd

可知 ID 位于第 3 列(C 列),Username 位于第 1 列(A 列),二者列差为 3 - 1 = 2。因此,查到 ID 单元格后,应取 cell.row, cell.column - 2 获取用户名。

以下是优化后的完整可运行代码:

触站AI
触站AI

专业的中文版AI绘画生成平台

下载
import openpyxl

def find_username_by_id(worksheet, target_id, id_column=3, username_column=1, max_rows=20):
    """
    根据 ID 在指定列中搜索,并返回同一行指定列(如 Username)的值

    :param worksheet: openpyxl worksheet 对象
    :param target_id: 待查找的 ID 字符串
    :param id_column: ID 所在列号(从 1 开始,如 C 列为 3)
    :param username_column: Username 所在列号(如 A 列为 1)
    :param max_rows: 最大搜索行数(可设为 worksheet.max_row 提升通用性)
    :return: 匹配的用户名,未找到则返回 None
    """
    for row in worksheet.iter_rows(
        min_row=1, 
        max_row=max_rows, 
        min_col=id_column, 
        max_col=id_column,
        values_only=False  # 需要 Cell 对象以获取 .row 属性
    ):
        cell = row[0]  # 每行仅一列,取第一个单元格
        if cell.value == target_id:
            return worksheet.cell(row=cell.row, column=username_column).value
    return None

# 主逻辑
benutzerid = "3993fj3a"  # 示例 ID
print(f"正在查找 ID: {benutzerid}")

# 验证 ID 格式(不含 '/')
if "/" not in benutzerid:
    try:
        wb = openpyxl.load_workbook("list.xlsx", read_only=True, data_only=True)
        ws = wb.active

        benutzer = find_username_by_id(
            worksheet=ws,
            target_id=benutzerid,
            id_column=3,           # C 列为 ID
            username_column=1,     # A 列为 Username
            max_rows=ws.max_row    # 动态适配实际行数,更健壮
        )

        wb.close()  # 显式关闭只读工作簿,释放资源

        if benutzer is None:
            benutzer = "UNKNOWNUSER"

        print(f"用户 ID '{benutzerid}' 对应的用户名是:{benutzer}")

    except FileNotFoundError:
        print("错误:未找到文件 'list.xlsx'")
        benutzer = "UNKNOWNUSER"
    except Exception as e:
        print(f"查找过程中发生异常:{e}")
        benutzer = "UNKNOWNUSER"
else:
    print("错误:ID 中包含非法字符 '/'")
    benutzer = "UNKNOWNUSER"

print(benutzer)

关键改进点说明:

  • 列定位精准化:不再遍历整表,而是限定 min_col=max_col=id_column,仅扫描 ID 所在列,大幅提升性能与准确性;
  • 偏移逻辑显式化:用 id_column 和 username_column 参数替代魔法数字(如 -9 或 -2),语义清晰且易于维护;
  • 健壮性增强:添加文件异常、空值判断及资源释放(wb.close()),避免 read_only=True 模式下潜在的内存占用问题;
  • 可扩展设计:函数支持自定义列号与最大行数,轻松适配不同表结构(如 ID 在 D 列、Username 在 B 列等场景)。

? 小贴士:
若 Excel 表头可能变动,建议先读取第一行定位列名(如 for idx, cell in enumerate(ws[1], 1): if cell.value == "ID": id_col = idx),实现动态列索引,进一步提升脚本鲁棒性。

通过以上方法,你将告别“总返回 UNKNOWNUSER”的困扰,实现稳定、高效、易维护的 Excel 值关联查找。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

799

2023.08.22

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

539

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

21

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

34

2026.01.06

excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1416

2023.07.25

excel重复项筛选标色
excel重复项筛选标色

excel的重复项筛选标色功能使我们能够快速找到和处理数据中的重复值。本专题为大家提供excel重复项筛选标色的相关的文章、下载、课程内容,供大家免费下载体验。

416

2023.07.31

excel复制表格怎么复制出来和原来一样大
excel复制表格怎么复制出来和原来一样大

本专题为大家带来excel复制表格怎么复制出来和原来一样大相关文章,帮助大家解决问题。

566

2023.08.02

excel表格斜线一分为二
excel表格斜线一分为二

在Excel表格中,我们可以使用斜线将单元格一分为二。本专题为大家带来excel表格斜线一分为二怎么弄的相关文章,希望可以帮到大家。

1249

2023.08.02

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

98

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 16.3万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号