在 Python 中对数据进行排序并从 CSV 文件生成表输出
假设我有以下 CSV 文件 (subjects.csv),
subjects,name1,name2,name3
Chemistry,Tom,Will,Rob
Biology,Megan,Sam,Tim
Physics,Tim,Will,Bob
Maths,Will,Tim,Joe
我想查找哪对学生共享同一班级,仅关注 Tim、Tom 和 Will。我该如何在 Python 中将它们配对呢?
即
蒂姆和威尔一起上两堂课。
汤姆和威尔一起上一节课。
此外,我想将其绘制在一个像我下面所写的表格上,其中两个轴上都有名称以及一对学生共享的班级数量(名称按字母升序或降序排序)。已经阅读了如何为整个 CSV 文件生成表格,但我无法从头开始制作表格,同时从 CSV 文件中剥离列和行。
Tim Tom Will
Tim 0 0 0
Tom 0 0 1
Will 2 0 0
这超出了我的个人技能范围水平,但我仍然想知道如何做并尝试理解。
Let's say I've got the following CSV file (subjects.csv)
subjects,name1,name2,name3
Chemistry,Tom,Will,Rob
Biology,Megan,Sam,Tim
Physics,Tim,Will,Bob
Maths,Will,Tim,Joe
I want to find which pairs of students share the same class, focusing only on Tim, Tom and Will. How would I go about pairing these in Python?
i.e.
Tim and Will attend 2 classes together.
Tom and Will attend in 1 class together.
Furthermore, I want to plot this on a table like what I've written below, where it has names on both axis and the number of classes a pair of students both share (with names sorted in ascending or descending alphabetical order).. I've read about how to generate tables for entire CSV files, but I can't get my head around making tables from scratch whilst at the same time, stripping columns and rows from the CSV file..
Tim Tom Will
Tim 0 0 0
Tom 0 0 1
Will 2 0 0
This is way out of my personal skill level, but I'd still like to know how to do it and try to understand.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您可以创建一个字典,其中包含每个学生正在参加的课程:
要检查人们一起参加了多少课程,您可以使用集合的交集方法:
要打印示例中的表格,您可以执行以下操作:
表格的标题可能是看起来像这样:
正如约翰在评论中提到的,我将名称硬编码到列表中,以模仿您上面给出的示例。要查看整个表,您可以使用
.iterkeys()
或.keys()
从您创建的字典中获取或迭代键:You can create a dictionary with what class each student is taking:
To check how many classes people are taking together you can use set's intersection method:
To print out the table in your example you can do something like this:
a header for the table might look like this:
As John mentions in the comments, I am hard coding the names into a list, to mimic the example you gave above. To see an entire table you can get or iterate the keys from the dictionary you created using
.iterkeys()
or.keys()
: