RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1591217
Accepted
polsok
polsok
Asked:2024-08-19 18:29:27 +0000 UTC2024-08-19 18:29:27 +0000 UTC 2024-08-19 18:29:27 +0000 UTC

将字典解析成表

  • 772

例如,给定包含数据的字典:

pers1 = {"Surname": "Ivanov", "Child": 3, "Age": "18"}

pers2 = dict([("Surname", "Petrov"), ("Name", "Ivan"), ("Age", "56")])

pers3 = dict([("Surname", "Sidorov"), ("Child", 1), ("Name", "Sergey")])

我怎样才能将这些数据传输到表中,使其看起来像这样:

一个 乙 C D
个人1 个人2 个人3
姓 伊万诺夫 彼得罗夫 西多罗夫
姓名 伊万 谢尔盖
年龄 18 56
孩子 1 3
python
  • 3 3 个回答
  • 74 Views

3 个回答

  • Voted
  1. AnnaBazueva
    2024-08-19T18:47:34Z2024-08-19T18:47:34Z

    例如使用Pandas:

    import pandas as pd
    
    # Данные из словарей
    pers1 = {"Surname": "Ivanov", "Child": 3, "Age": "18"}
    
    pers2 = dict([("Surname", "Petrov"), ("Name", "Ivan"), ("Age", "56")])
    
    pers3 = dict([("Surname", "Sidorov"), ("Child", 1), ("Name", "Sergey")])
    
    # Получаем имена переменных из locals()
    names = [name for name in locals() if name.startswith('pers')]
    
    # Создаем список словарей
    data = [locals()[name] for name in names]
    
    # Создаем DataFrame
    df = pd.DataFrame(data, index=names)
    
    # Транспонируем DataFrame, чтобы ключи стали индексами строк
    df = df.T
    
    # Заполняем отсутствующие значения NaN
    df.fillna('', inplace=True)
    
    # Задаем нужный порядок строк
    desired_order = ['Surname', 'Name', 'Age', 'Child']
    df = df.reindex(desired_order)
    
    # Выводим таблицу (Вы можете записать в data.xlsx)
    print(df)
    

    输出:

    (.venv) PS C:\KWORK> & c:/KWORK/.venv/Scripts/python.exe c:/KWORK/MyUserBot/ruSo.py  
              pers1   pers2    pers3
    Surname   Ivanov  Petrov   Sidorov
    Name              Ivan     Sergey
    Age       18      56
    Child     3.0              1.0
    
    • 3
  2. Best Answer
    Oopss
    2024-08-19T20:31:40Z2024-08-19T20:31:40Z
    from pyexcelerate import Workbook
    
    
    pers1 = {"Name": "Ivanov", "Child": 3, "Age": "18"}
    pers2 = dict([("Name", "Petrov"), ("Surname", "Ivan"), ("Age", "56")])
    pers3 = dict([("Name", "Sidorov"), ("Child", 1), ("Surname", "Sergey")])
    
    # Список словарей
    data = [pers1, pers2, pers3]
    
    # Создаем Workbook и Worksheet
    wb = Workbook()
    ws = wb.new_sheet("Лист1")
    
    # Записываем заголовки
    headers=["Name","Surname","Child","Age"]
    
    ## Здесь можно переписать все ключи-заголовки, но порядок не могу определить
    # for dict_pers in data:
    #     for dict_key in dict_pers:
    #         headers.append(dict_key)
    #headers = []
    # headers = list(set(headers))
    # print(headers)
    
    #Первый столбик заголовки
    for row, header in enumerate(headers, 1):
        ws.set_cell_value(row, 1, header)
    
    # Записываем данные
    for row, header in enumerate(headers, 1):
        for col, pers in enumerate(data, 2):
            ws.set_cell_value(row, col, pers.get(header, " "))
    
    # Сохраняем файл
    wb.save("pers.xlsx")
    

    在此输入图像描述

    • 3
  3. Fox Fox
    2024-08-19T21:34:32Z2024-08-19T21:34:32Z

    看着数据,我不禁笑了。名字和姓氏很容易混淆,18 岁的伊万诺夫有 3 个孩子(!),而彼得罗夫甚至没有零个孩子。任何甚至有点称职和熟练的经理都会说,特征几乎总是列,而会计主体(在本例中为人)是行。否则,这样一张表能容纳多少科目,可读性如何?在正确设计的表格中,可以正常按列排序、设置过滤器,甚至可以将其保存在 csv 中以便在其他程序中使用,而无需任何麻烦。

    我将展示此类算法的示例(您需要安装openpyxl模块):

    import os
    import openpyxl
    
    # Данные
    person1 = {"Фамилия": "Иванов", "Имя": "Иван", "Дети": 3, "Возраст": 28}
    person2 = {"Фамилия": "Петров", "Имя": "Пётр", "Дети": 0, "Возраст": 18}
    person3 = {"Фамилия": "Сидоров", "Имя": "Сидор", "Дети": 1, "Возраст": 25}
    citizens = [person1, person2, person3]
    
    # Создание Excel файла
    wb = openpyxl.Workbook() # книга
    ws = wb.active # активный лист
    ws.append(list(citizens[0].keys())) # запись заголовка
    for person in citizens: ws.append(list(person.values())) # запись данных
    wb.save("citizens.xlsx") # сохранение файла
    
    print("\nНажмите любую клавишу для продолжения...")
    os.system("pause > nul")
    

    该示例已完全准备就绪,将文本另存为 .py,安装 openpyxl,您可以自行测试和调整它。

    • 3

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5