分别计算男女宿舍

2024-05-02

我想要的结果是这样的

(males {1990: {Q1:value, Q2:value, Q3:Value, Q4: Value}, 
 females {Q1:value, Q2:value, Q3:Value, Q4:value})

如果任何值不存在则默认值 0

import csv
male_count = {}
female_count = {}


 with open('1000 Records.csv') as csv_file:
    
    csv_reader = csv.reader(csv_file)
    for row in csv_reader:
        
        year_of_joining = int(row[17])
        quarter_of_joining = row[15]
        gender = row[5]
        
        if year_of_joining not in female_count and gender == 'F':
            female_count[year_of_joining] = {'Q1': 0, 'Q2': 0, 'Q3': 0, 'Q4': 0}
            female_count[year_of_joining][quarter_of_joining] = 1
        elif year_of_joining in female_count and gender == 'F':
            female_count[year_of_joining][quarter_of_joining] += 1

        if year_of_joining not in male_count and gender == 'M':
            male_count[year_of_joining] = {'Q1': 0, 'Q2': 0, 'Q3': 0, 'Q4': 0}
            male_count[year_of_joining][quarter_of_joining] = 1
        elif year_of_joining in male_count and gender == 'M':
            male_count[year_of_joining][quarter_of_joining] += 1
print(male_count)
print(female_count)

假设您想要单独的字典,而不是“性别,按年份分组”(意味着年份是两个性别字典的顶级键),答案与您的上一个问题基本相同,除了您有两个单独的“result" 字典(你可以组合它们,因为 Python 对象是引用)

import csv

males = {}
females = {}

with open('records.csv') as csv_file:
  csv_reader = csv.DictReader(csv_file)
  for row in csv_reader: 
        
    year_of_joining = int(row['Year of Join'])
    quarter_of_joining = row['Quarter of Join']
    gender = row['Gender']
    result = males if gender == 'M' else females
    
    if year_of_joining not in result:
      result[year_of_joining] = {f'Q{i+1}': 0 for i in range(4)}
        
    result[year_of_joining][quarter_of_joining] += 1

final_result = {"males": males, "females": females} 

Input

Gender,Year of Join,Quarter of Join
F,2010,Q1
M,2010,Q2
F,2017,Q1

Output

from pprint import pprint
print('males', end=' ')
pprint(males)
print('females', end=' ')
pprint(females)
males {2010: {'Q1': 0, 'Q2': 1, 'Q3': 0, 'Q4': 0}}
females {2010: {'Q1': 1, 'Q2': 0, 'Q3': 0, 'Q4': 0},
 2017: {'Q1': 1, 'Q2': 0, 'Q3': 0, 'Q4': 0}}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

分别计算男女宿舍 的相关文章

随机推荐

  • 哪个 SVG/SMIL DOM 元素具有“beginElement”方法?

    最终 这是针对将在 Firefox 中运行的 Kiosk 风格的应用程序 使用 jQuery 1 6 4 因此答案可能是特定于 Firefox 的 我正在尝试制作动画 SVG 但我正在尝试通过动态插入 SMIL 来为其设置动画 我没有看到任
  • 构建复杂 NSCompoundPredicate 的最佳方法是什么?

    我需要建立一个NSPredicate有很多数据 例如 在 SQL 中我会执行如下操作 SELECT FROM TRANSACTIONS WHERE CATEGORY IN categoryList AND LOCATION IN locat
  • 在ggplot2中按线连接分组点

    我试图将每组的每个蓝点与其相应的红点连接起来 但是 我在使用时遇到问题geom segment 谢谢帮助 repl lt data frame title c A B C A B C diff c 10 06 1 89 12 79 10 0
  • 我可以让 C++ 编译器在编译时实例化对象吗?

    我正在编写一些代码 其中包含大量相当简单的对象 我希望它们在编译时创建 我认为编译器能够做到这一点 但我无法弄清楚如何做到 In C我可以执行以下操作 include
  • 查找一个列表在另一个列表中的值的索引

    我有两个 Python 整数列表 x and y 的所有元素x出现在某处y 而且只有一次 对于每个元素x 我想知道对应值的索引y 然后我想将这些索引设置为一个列表z 下面的代码按照我刚刚描述的方式工作 然而 对于一项任务来说 这似乎有点笨拙
  • 与超类和子类构造函数接口

    我在 matlab 文档和之前有关使用 matlab 继承和类构造函数创建接口的问题中找不到帮助 为了使其整洁 放在一个包内 我可以将其压缩如下 而不是拖拽代码 一套 MyPkg有一个超类Super和一些子类Sub1 Sub2 我的大多数属
  • Cookie 未存储在浏览器中

    与 一起工作Next js and Django Rest Framework 我正在使用 JWT 对用户进行身份验证 首先 当用户成功登录页面时 会将 cookie 包含 JWT 令牌 发送到浏览器 当用户尝试访问特定页面时 此 cook
  • HTML Canvas:如何绘制翻转/镜像图像?

    当我在 HTML 画布上绘制图像时 我试图翻转 镜像图像 我发现一个游戏教程显示了角色必须面对的每个方向的精灵表 但这对我来说似乎不太正确 特别是因为每个框架都有不同的尺寸 实现这一目标的最佳技术是什么 我尝试致电setScale 1 1
  • Angular Universal - 不应使用超时

    所以我一直在尝试将我的应用程序转换为角度通用的 并且在大多数情况下它都很好 但我之前读过一些 陷阱 https github com onespeed articles angular universal gotchas https git
  • C++ 将浮点数转换为无符号字符?

    我是 C 新手 我想做了一些谷歌搜索sprintf可以完成这项工作 但是编译时出现错误 无法在unsigned char and a char 我需要一个无符号字符 因为我要打印到图像文件 0 255 RGB unsigned char p
  • vba powerpoint按名称选择幻灯片

    我正在尝试按名称选择一张幻灯片 我通过大纲添加了标题 下面是不起作用的代码 在幻灯片集合中找不到爱达荷州项目 ActivePresentation Slides Idaho Select 幻灯片的名称和标题占位符中的文本彼此无关 除非您已重
  • Android 屏幕上的触摸事件

    我想找出当用户触摸 Android 的任何屏幕时发生的任何事件 我发现特定活动的触摸事件 但不是所有屏幕 请给我一个 解决方案 试试这个代码 Override public boolean onTouchEvent MotionEvent
  • OpenGL z轴指向哪里?

    我正在尝试了解 OpenGL 坐标系 我到处都看到它被描述为右撇子 但这与我的经验不符 我尝试绘制一些形状和 3 d 对象 我发现 z 轴显然指向 屏幕 而 x 指向右侧 y 指向上方 这是左手坐标系的描述 我缺少什么 编辑 例如 http
  • 如何正确关闭资源

    当我清理一些代码时 FindBugs 向我指出了一些使用 Connection CallableStatement 和 ResultSet 对象的 JDBC 代码 这是该代码的一个片段 CallableStatement cStmt get
  • 使用 ZF3 在模块引导程序中无法访问视图助手管理器

    Using Zend Framework 2我可以访问ViewHelperManager这样做 public function onBootstrap MvcEvent e viewHelperManager e gt getApplica
  • 似乎无法在 NSMenuItem 上 setEnabled:NO

    我已经子类化了NSMenu并连接了一堆NSMenuItem通过界面生成器 我已经通过调试器进行了测试 看看它们确实得到了初始化 菜单设置为不自动启用项目 仍然当我将任何 NSMenuItem 设置为 myMenuItem setEnable
  • 一条指令可以同时处于两种寻址模式吗?

    我在书中读到了以下内容从头开始编程 处理器有多种不同的访问数据的方式 称为 寻址模式 最简单的模式是立即模式 其中 要访问的数据嵌入在指令本身中 例如 如果我们想将寄存器初始化为 0 而不是给出 计算机要从中读取 0 的地址 我们将指定立即
  • 如何通过pygit2获取当前签出的Git分支名称?

    这个问题应该与 如何获取Git中当前的分支名称 https stackoverflow com questions 6245570 how to get current branch name in git 获取 git 当前分支 标签名称
  • 当包含 textColor 的样式应用于 textView 的 textAppearance 时,文本的颜色不会改变

    我想减少 xml 代码的重复 所以我为textView中的文本做了一些标准样式 我们可以在textView中的 style 属性和 android textAppearance 属性下应用样式 以下是我为文本外观制作的一些样式
  • 分别计算男女宿舍

    我想要的结果是这样的 males 1990 Q1 value Q2 value Q3 Value Q4 Value females Q1 value Q2 value Q3 Value Q4 value 如果任何值不存在则默认值 0 imp