- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一些类似格式的数据:
James has 6 jeans, 10 shirts, 5 shoes, 6 ties
Nick has 8 jeans, 4 shirts, 3 shoes, 4 ties
Adam has 2 jeans, 3 shirts, 5 shoes, 1 tie
John has 6 jeans, 5 shirts, 10 shoes, 3 ties
使用 collections.defaultdict(list)
,我生成了以下格式的字典:
{James: [[Jeans, 6],
[Shirts, 10],
[Shoes, 5],
[Ties, 6]],
Nick: [[Jeans, 8],
[Shirts, 4],
[Shoes, 3],
[Ties, 4]],
Adam: [[Jeans, 2],
[Shirts, 3],
[Shoes, 5],
[Ties, 1]],
John: [[Jeans, 6],
[Shirts, 5],
[Shoes, 10],
[Ties, 3]]}
我试图在 cvs 电子表格中获取此输出:
Accesories James Nick Adam John
Jeans 6 8 2 6
Shirts 10 4 3 5
Shoes 5 3 5 10
Ties 6 4 1 3
在构建字典之前进行了一些编码之后,这里是我到目前为止尝试使用创建的字典生成与上述格式相同的电子表格的代码。 cvs
,itertools
模块已经导入。
with open(outputcsv, 'w') as w:
writer = csv.writer(w, delimiter=',', lineterminator='\n')
writer.writerow(dict.keys())
zipped = itertools.izip_longest(*dict.values())
writer.writerows(list(zipped))
这让我非常接近预期的解决方案,但又不完全是。
最佳答案
作为一个字典的字典,而不是一个列表列表的字典,这会更容易。
假设:
w={'James': {'Jeans': 6,
'Shirts': 10,
'Shoes': 5,
'Ties': 6,},
'Nick': {'Jeans': 8,
'Shirts': 4,
'Shoes': 3,
'Ties': 4},
'Adam': {'Jeans': 2,
'Shirts': 3,
'Shoes': 5,
'Ties': 1},
'John': {'Jeans': 6,
'Shirts': 5,
'Shoes': 10,
'Ties': 3,
'Belts': 1}}
注意 John
有腰带而其他人没有,这是一个字典的字典,而不是两个元素列表的字典。
首先,让我们列出一份(好吧,一套...)任何人拥有的所有配件:
accessories=set()
for nam, di in w.items():
for k in di:
accessories.add(k)
>>> accessories
set(['Ties', 'Belts', 'Jeans', 'Shirts', 'Shoes'])
现在可以直接以您的格式创建这些项目的 CSV:
import csv
with open('/tmp/so.csv', 'w') as f:
writer=csv.writer(f)
writer.writerow(['accessories']+w.keys())
for item in accessories:
li=[item]
for nam in w:
li.append(w[nam].get(item, 0))
writer.writerow(li)
现在查看文件:
accessories,James,John,Adam,Nick
Ties,6,3,1,4
Belts,0,1,0,0
Jeans,6,6,2,8
Shirts,10,5,3,4
Shoes,5,10,5,3
如果您坚持使用每两个元素的列表列表的字典(就像您在示例中所做的那样),您可以转换它们:
>>> w={'James': [['Jeans', 6],
... ['Shirts', 10],
... ['Shoes', 5],
... ['Ties', 6]],
... 'Nick': [['Jeans', 8],
... ['Shirts', 4],
... ['Shoes', 3],
... ['Ties', 4]],
... 'Adam': [['Jeans', 2],
... ['Shirts', 3],
... ['Shoes', 5],
... ['Ties', 1]],
... 'John': [['Jeans', 6],
... ['Shirts', 5],
... ['Shoes', 10],
... ['Ties', 3],
... ['Belts', 1]]}
>>> {k:dict(LoL) for k, LoL in w.items()}
{'James': {'Ties': 6, 'Jeans': 6, 'Shirts': 10, 'Shoes': 5}, 'John': {'Ties': 3, 'Belts': 1, 'Jeans': 6, 'Shirts': 5, 'Shoes': 10}, 'Adam': {'Ties': 1, 'Jeans': 2, 'Shirts': 3, 'Shoes': 5}, 'Nick': {'Ties': 4, 'Jeans': 8, 'Shirts': 4, 'Shoes': 3}}
关于python - 在 Python 中将字典解析为电子表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33324521/
我这里有一个工作示例。 https://developers.google.com/google-apps/spreadsheets/我需要从用户的谷歌文档下载一些文件。 import com.goo
我需要您在以下方面的帮助: 假设我们有 3 个不同的组:(A、B、C) 我们在每个组中有几个值范围: (Eg. A has 0 - 100, 101 - 200 while B has 0 - 200
谁能告诉我有什么方法可以从 python 连接到电子表格吗?我想从表单中存储一些数据并将其提交到谷歌电子表格。请帮助解决这个问题。我必须遵循哪些步骤? 提前致谢... 最佳答案 连接到 Google
我正在尝试计算 2019 年给定时间范围内的月数。 我的数据如下所示: 我将开始日期和结束日期列的格式更改为“日期”。 “以月为单位的持续时间”和输出列具有数字格式。 我接近它如下: 如果开始日期(年
在设计上有一点问题,希望我能在这里寻求建议。接受 grails 可能是完全错误的工具,但这就是生活。 所以一直在努力开发一个网络应用程序,该应用程序基本上只是从谷歌电子表格中呈现大量信息并发回一些更新
我正在设计一个胖客户端(即非浏览器)Python 应用程序,它将与托管数据库进行通信。该应用程序的屏幕之一需要有一个网格/电子表格区域,允许显示多行数据、过滤、排序和更新多行信息。有人推荐一个具有此功
我在 Django 中有一个表单,可以将用户添加到 mySQL 数据库。然而,用户将不得不添加大量用户,并且一些信息将被复制和粘贴。所以我在想是否有一种方法可以有一个类似表单的电子表格,其中列标题是将
我在 Outlook VBA 中编写了一个程序,它根据 Excel 电子表格的内容创建一些电子邮件。一切正常,但是当程序终止时,我继续运行“EXCEL.EXE”进程,该进程会锁定电子表格,因此其他人无
如何使用公式来确定当前时区? 我使用的公式给出了意想不到的结果。 我的电子表格设置(文件 > 电子表格设置...): 时区: (GMT+01:00) 阿姆斯特丹 我使用的公式: =TEXT(NOW()
如何转换持续时间的小时数? 示例:在单元格 A1 中,我有 176 . 我希望单元格 A2 有 176:00:00 我想在 176 小时(持续时间)内转换数字 176。那可能吗?因为如果我在单元格中键
我收到了 4 个不同的采购订单,上面有一个随机的采购订单编号。 我仅在 A 列中填写采购订单号。 对于这个例子,我收到了下面列出的 4 个不同的采购订单。 采购订单 697533 - 2 项 采购订单
我需要编写循环遍历数据列的程序。根据单元格值和代表变量的每一列重置变量。 练习中的变量取决于循环的这些值。 如何在循环的每次迭代中将值增加 1 来循环遍历行? df=pd.DataFrame(r'C:
我正在做一些详尽的搜索,需要确定新域 (URL) 是否已经在电子表格中。但是,没有一个电子表格对象具有搜索功能,即在大多数文档对象中找到的 findText()。我觉得我错过了一些重要的东西。 我错过
我正在尝试在 Pandas 中导入一个 excel 电子表格,但由于数据“由用户在视觉上构建”以在视觉上对用户友好并且没有使用正确的数据结构,因此我遇到了一些问题。 结果,当在 Pandas 中作为数
我必须在 HTML 页面上显示多个图表,但我无法进行多个查询(直接在 google 电子表格上)。 实际上,我只是第一个查询显示的是谁。 我的代码: Page de pilotage
我使用以下代码作为将 html 网站上的用户输入数据发送到 Google 电子表格的方法: Javascript: function postContactToGoogle() { v
我有一个使用 Google Drive 和电子表格 API 的网站。我想要做的是,如果没有找到具有特定条件的电子表格,则在用户的 Google 云端硬盘上创建电子表格。该电子表格应该是我的 Googl
我目前链接到六个 Excel 电子表格,主要是因为用户在 Excel 中编辑数据更容易/更好(他们从未使用过 Access),而且任何更改都会立即反射(reflect),包括是否有新列添加后即可立即供
我正在努力通过 PowerShell 添加指向可变长度电子表格的链接,无论如何我都会遇到错误。这是我目前正在尝试制作的循环,它嵌套在一个 excel comobject 中, $sheet 代表 $e
在 Excel 电子表格中编写许多工作表可能需要一段时间。并行化它会很有帮助。 此代码运行良好,它使一个 Excel 电子表格在屏幕上弹出,其中包含四个名为 Sheet1、1、2 的工作表 和 3。
我是一名优秀的程序员,十分优秀!