[PY3]——根据某个特定的字段来分组迭代访问一个字段或序列?/ itertools.groupby( )函数

问题

你有一个字典或者实例的序列,然后你想根据某个特定的字段(比如‘date’)来分组迭代访问。

解决方案

itertools.groupby( )函数

itertools.groupby(rows,key=itemgetter(‘字段‘))

  • groupby( )函数扫描整个序列并且查找连续相同值(或者根据指定 key函数返回值相同)的元素序列
  • 在调用groupby( )函数前,我们首先需要按照这个字段来排序(这和SQL语句中的group by的使用是一个道理)
  • 因为groupby( )仅仅检查连续的元素,如果事先并没有排序完成的话,分组函数将得不到想要的结果
rows = [
    {‘address‘: ‘5412 N CLARK‘, ‘date‘: ‘07/01/2012‘},
    {‘address‘: ‘5148 N CLARK‘, ‘date‘: ‘07/04/2012‘},
    {‘address‘: ‘5800 E 58TH‘, ‘date‘: ‘07/02/2012‘},
    {‘address‘: ‘2122 N CLARK‘, ‘date‘: ‘07/03/2012‘},
    {‘address‘: ‘5645 N RAVENSWOOD‘, ‘date‘: ‘07/02/2012‘},
    {‘address‘: ‘1060 W ADDISON‘, ‘date‘: ‘07/02/2012‘},
    {‘address‘: ‘4801 N BROADWAY‘, ‘date‘: ‘07/01/2012‘},
    {‘address‘: ‘1039 W GRANVILLE‘, ‘date‘: ‘07/04/2012‘},
]
from operator import itemgetter
from itertools import groupby
rows.sort(key=itemgetter(‘date‘))
print(rows)

  [{‘date‘: ‘07/01/2012‘, ‘address‘: ‘5412 N CLARK‘}, {‘date‘: ‘07/01/2012‘, ‘address‘: ‘4801 N BROADWAY‘}, {‘date‘: ‘07/02/2012‘, ‘address‘: ‘5800 E 58TH‘}, {‘date‘: ‘07/02/2012‘, ‘address‘: ‘5645 N RAVENSWOOD‘}, {‘date‘: ‘07/02/2012‘, ‘address‘: ‘1060 W ADDISON‘}, {‘date‘: ‘07/03/2012‘, ‘address‘: ‘2122 N CLARK‘}, {‘date‘: ‘07/04/2012‘, ‘address‘: ‘5148 N CLARK‘}, {‘date‘: ‘07/04/2012‘, ‘address‘: ‘1039 W GRANVILLE‘}]

for date,items in groupby(rows,key=itemgetter(‘date‘)):
    print(date)
    for i in items:
        print(‘ ‘,i)
07/01/2012
{‘date‘: ‘07/01/2012‘, ‘address‘: ‘5412 N CLARK‘}
{‘date‘: ‘07/01/2012‘, ‘address‘: ‘4801 N BROADWAY‘}
07/02/2012
{‘date‘: ‘07/02/2012‘, ‘address‘: ‘5800 E 58TH‘}
{‘date‘: ‘07/02/2012‘, ‘address‘: ‘5645 N RAVENSWOOD‘}
{‘date‘: ‘07/02/2012‘, ‘address‘: ‘1060 W ADDISON‘}
07/03/2012
{‘date‘: ‘07/03/2012‘, ‘address‘: ‘2122 N CLARK‘}
07/04/2012
{‘date‘: ‘07/04/2012‘, ‘address‘: ‘5148 N CLARK‘}
{‘date‘: ‘07/04/2012‘, ‘address‘: ‘1039 W GRANVILLE‘}
时间: 2024-10-05 09:13:45

[PY3]——根据某个特定的字段来分组迭代访问一个字段或序列?/ itertools.groupby( )函数的相关文章

SQL 将一条记录中多个字段的值拼接为一个字段 && 将多行数据合并成一行,并且拼接CONVERT() 、for xml path的使用

接着上篇文章的订单表(商品编号,价格设置时间id(类似于创建时间,创建时间约早,则act_id越小) ,价格的时间段,商品价格) 一.将一条记录中多个字段的值拼接为一个字段 现要求将两个时间段合并为一个字段,应该如何做呢? 先来看下理想的结果: 查询出的时间段合并到一起了: 代码如下,将查询的字段用+'你想要的符号' + 拼接即可 select item,act_id,loc_id,convert(varchar(100),start_date,20)+ '-' +convert(varchar

jmeter--正则提取json串中一个大括号对象里指定字段值的的另一个字段的值

需要提取如图红框_id的值,整个返回里有多个类似的大括号对象: 里面的第一个id的值,但是整个json串不止这么一个,并且只能匹配quality_level是349的这个大括号里的第一个id的值.下面使用3种方法: 第一种:最笨的方法,所有字段都写出来做匹配 {"_id":"(.{10,30}?)","agent":{"_id":"[^"]*?","name":"[^

sql 以某个字段分组,另一个字段为参加比较的列,取得前n项的值

假设表A有三个字段 { id int: subject varchar(20): socre int: } 语句为 select * from A  x where (select count(*) from A where subject=x.subject and score>=x.score   )<=15

【SQL】表A多个字段,关联表B一个字段说明

问题:查询资源的分配人姓名,顾问姓名 资源表crm 资源id,分配人id,顾问id 用户表user 用户id,用户name 解决办法: SELECT crm.id, user1.name, user2.name FROM crm LEFT JOIN user1 ON crm.blind_id = user1.id LEFT JOIN user2 ON crm.work_id = user2.id 原文地址:https://www.cnblogs.com/87060524test/p/112092

mysql select将多个字段横向合拼到一个字段

select concat(name, '的年龄是', age) as des from tbl_user; 结果: des 张三的年龄是10 李四的年龄是11 王五的年龄是12 原文地址:https://www.cnblogs.com/wsnan/p/11637062.html

awk加Sort实现对前N-1个字段作Key,最后一个字段作Value的排序

最近有一些数据,形如: a1,asdff,dddd,23 zz,ss,ff,hh,kk,56 pppp,90 Wwww,qqq,eee,ttt,yyy,44 这样的数据,需要将前面的N-1个字段作为Key,最后一个字段做Value,并根据Value排序,琢磨了很久,终于初步实现了,故在此备注和分享: awk 'BEGIN{FS=","; OFS=" "}{ <span style="white-space:pre"> </spa

TSQL--按某字段列分组,在将各组中某列合并成一行

鉴于群里很多同事在问这个问题,我简单写个Demo,希望对初学者有帮助! 无真相,无解说,不解释,直接上Code! --================================================== --示例代码,仅供参考 --按照object_id分组,将同一组的name列的值合并在一起 SELECT OBJECT_NAME(T1.object_id) AS ObjectName , ( SELECT T2.name + ',' FROM sys.all_columns T

对数据库表中的某一字段去重分组排序

1.问题背景    某数据库t_tab_ab中有两个字段a和b,如下所示:    查询前:                 查询后:    a     b                  a     b    1     2                  1     2    1     3                  2     3    1     4                  3     4    1     5    2     3    2     4    2  

MySQL group by 单字分组序和多字段分组

我这里创建了一个 goods 表,先看下里面的数据: mysql> select * from goods; +----+------+------+------------+-------------+------------+ | id | s_id | b_id | goods_name | goods_price | goods_desc | +----+------+------+------------+-------------+------------+ |  1 |    1