{"id":983,"date":"2023-07-28T02:29:34","date_gmt":"2023-07-28T02:29:34","guid":{"rendered":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/"},"modified":"2023-07-28T02:29:34","modified_gmt":"2023-07-28T02:29:34","slug":"pandas-groupby-agrega-multiplas-colunas","status":"publish","type":"post","link":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/","title":{"rendered":"Pandas: como agrupar e agregar em v\u00e1rias colunas"},"content":{"rendered":"<p><\/p>\n<hr>\n<p><span style=\"color: #000000;\">Freq\u00fcentemente, voc\u00ea pode querer agrupar e agregar v\u00e1rias colunas de um DataFrame do pandas.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Felizmente, isso \u00e9 f\u00e1cil de fazer usando as fun\u00e7\u00f5es <a href=\"https:\/\/pandas.pydata.org\/docs\/reference\/api\/pandas.DataFrame.groupby.html\" target=\"_blank\" rel=\"noopener noreferrer\">.groupby()<\/a> e <a href=\"https:\/\/pandas.pydata.org\/docs\/reference\/api\/pandas.DataFrame.agg.html\" target=\"_blank\" rel=\"noopener noreferrer\">.agg()<\/a> do pandas.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Este tutorial explica v\u00e1rios exemplos de uso pr\u00e1tico dessas fun\u00e7\u00f5es.<\/span><\/p>\n<h3> <span style=\"color: #000000;\"><strong>Exemplo 1: Agrupe por duas colunas e encontre a m\u00e9dia<\/strong><\/span><\/h3>\n<p> <span style=\"color: #000000;\">Suponha que temos o seguinte DataFrame do pandas:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #107d3f;\">import<\/span> pandas <span style=\"color: #107d3f;\">as<\/span> pd\n\n<span style=\"color: #008080;\">#createDataFrame<\/span>\ndf = pd.DataFrame({'team': ['A', 'B', 'B', 'B', 'B', 'M', 'M', 'M'],\n                   'position': ['G', 'G', 'F', 'G', 'F', 'F', 'C', 'C'],\n                   'assists': [5, 7, 7, 8, 5, 7, 6, 9],\n                   'rebounds': [11, 8, 10, 6, 6, 9, 6, 10]})\n\n<span style=\"color: #008080;\">#view DataFrame\n<\/span><span style=\"color: #993300;\">print<\/span> (df)\n\n  team position assists rebounds\n0 AG 5 11\n1 BG 7 8\n2 BF 7 10\n3 BG 8 6\n4 BF 5 6\n5 MF 7 9\n6 MC 6 6\n7 MC 9 10\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">O c\u00f3digo a seguir mostra como agrupar por colunas \u201cequipe\u201d e \u201cposi\u00e7\u00e3o\u201d e encontrar a m\u00e9dia de passes:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong>df. <span style=\"color: #3366ff;\">groupby<\/span> (['team', 'position']). <span style=\"color: #3366ff;\">agg<\/span> ({'assists': ['mean']}). <span style=\"color: #3366ff;\">reset_index<\/span> ()\n\n\n        team position assists\n                          mean\n0 A G 5.0\n1 B F 6.0\n2 B G 7.5\n3 M C 7.5\n4M F 7.0\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">A sa\u00edda nos diz:<\/span><\/p>\n<ul>\n<li> <span style=\"color: #000000;\">A m\u00e9dia de assist\u00eancias dos jogadores da posi\u00e7\u00e3o G da equipe A \u00e9 de <strong>5,0<\/strong> .<\/span><\/li>\n<li> <span style=\"color: #000000;\">A m\u00e9dia de assist\u00eancias dos jogadores da posi\u00e7\u00e3o F da equipe B \u00e9 de <strong>6,0<\/strong> .<\/span><\/li>\n<li> <span style=\"color: #000000;\">A m\u00e9dia de assist\u00eancias dos jogadores da posi\u00e7\u00e3o G da equipe B \u00e9 de <strong>7,5<\/strong> .<\/span><\/li>\n<\/ul>\n<p> <span style=\"color: #000000;\">E assim por diante.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Tamb\u00e9m podemos usar o seguinte c\u00f3digo para renomear as colunas do DataFrame resultante:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008080;\">#group by team and position and find mean assists<\/span>\nnew = df. <span style=\"color: #3366ff;\">groupby<\/span> (['team', 'position']). <span style=\"color: #3366ff;\">agg<\/span> ({'assists': ['mean']}). <span style=\"color: #3366ff;\">reset_index<\/span> ()\n\n<span style=\"color: #008080;\">#rename columns<\/span>\nnew.columns = ['team', 'pos', 'mean_assists']\n\n<span style=\"color: #008080;\">#view DataFrame<\/span>\n<span style=\"color: #993300;\">print<\/span> (new)\n\n\tteam pos mean_assists\n0 A G 5.0\n1 B F 6.0\n2 B G 7.5\n3 M C 7.5\n4M F 7.0<\/strong><\/pre>\n<h3> <span style=\"color: #000000;\"><strong>Exemplo 2: Agrupar por duas colunas e encontrar m\u00faltiplas estat\u00edsticas<\/strong><\/span><\/h3>\n<p> <span style=\"color: #000000;\">Vamos supor que estamos usando o mesmo DataFrame do pandas do exemplo anterior:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #107d3f;\">import<\/span> pandas <span style=\"color: #107d3f;\">as<\/span> pd\n\n<span style=\"color: #008080;\">#createDataFrame<\/span>\ndf = pd.DataFrame({'team': ['A', 'B', 'B', 'B', 'B', 'M', 'M', 'M'],\n                   'position': ['G', 'G', 'F', 'G', 'F', 'F', 'C', 'C'],\n                   'assists': [5, 7, 7, 8, 5, 7, 6, 9],\n                   'rebounds': [11, 8, 10, 6, 6, 9, 6, 10]})<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">O c\u00f3digo a seguir mostra como encontrar a mediana e o n\u00famero m\u00e1ximo de rebotes, agrupados nas colunas \u201cequipe\u201d e \u201cposi\u00e7\u00e3o\u201d:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong>df. <span style=\"color: #3366ff;\">groupby<\/span> (['team', 'position']). <span style=\"color: #3366ff;\">agg<\/span> ({'rebounds': ['median', 'max']}). <span style=\"color: #3366ff;\">reset_index<\/span> ()\n\n\n        team position rebounds\n                         median max\n0 A G 11 11\n1 B F 8 10\n2 B G 7 8\n3 M C 8 10\n4 M F 9 9\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">A sa\u00edda nos diz:<\/span><\/p>\n<ul>\n<li> <span style=\"color: #000000;\">A mediana de rebotes para jogadores na posi\u00e7\u00e3o G do Time A \u00e9 <strong>11<\/strong> .<\/span><\/li>\n<li> <span style=\"color: #000000;\">O m\u00e1ximo de rebotes para jogadores na posi\u00e7\u00e3o G da equipe A \u00e9 <strong>11<\/strong> .<\/span><\/li>\n<li> <span style=\"color: #000000;\">A mediana de rebotes dos jogadores na posi\u00e7\u00e3o F do time B \u00e9 <strong>8<\/strong> .<\/span><\/li>\n<li> <span style=\"color: #000000;\">O m\u00e1ximo de rebotes para jogadores na posi\u00e7\u00e3o F do time B \u00e9 <strong>10<\/strong> .<\/span><\/li>\n<\/ul>\n<p> <span style=\"color: #000000;\">E assim por diante.<\/span><\/p>\n<h3> <span style=\"color: #000000;\"><strong>Recursos adicionais<\/strong><\/span><\/h3>\n<p> <a href=\"https:\/\/statorials.org\/pt\/pandas-filtram-multiplas-condicoes\/\" target=\"_blank\" rel=\"noopener noreferrer\">Como filtrar um DataFrame do Pandas em m\u00faltiplas condi\u00e7\u00f5es<\/a><br \/> <a href=\"https:\/\/statorials.org\/pt\/pandas-contam-valores-faltantes\/\" target=\"_blank\" rel=\"noopener noreferrer\">Como contar valores ausentes em um DataFrame do Pandas<\/a><br \/> <a href=\"https:\/\/statorials.org\/pt\/empilhar-dataframes-do-pandas\/\" target=\"_blank\" rel=\"noopener noreferrer\">Como empilhar v\u00e1rios DataFrames Pandas<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Freq\u00fcentemente, voc\u00ea pode querer agrupar e agregar v\u00e1rias colunas de um DataFrame do pandas. Felizmente, isso \u00e9 f\u00e1cil de fazer usando as fun\u00e7\u00f5es .groupby() e .agg() do pandas. Este tutorial explica v\u00e1rios exemplos de uso pr\u00e1tico dessas fun\u00e7\u00f5es. Exemplo 1: Agrupe por duas colunas e encontre a m\u00e9dia Suponha que temos o seguinte DataFrame do [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[11],"tags":[],"class_list":["post-983","post","type-post","status-publish","format-standard","hentry","category-guia"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v21.5 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Pandas: como agrupar e agregar em v\u00e1rias colunas<\/title>\n<meta name=\"description\" content=\"Uma explica\u00e7\u00e3o simples de como agrupar e agregar m\u00faltiplas colunas em um DataFrame do pandas, incluindo exemplos.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/\" \/>\n<meta property=\"og:locale\" content=\"pt_PT\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Pandas: como agrupar e agregar em v\u00e1rias colunas\" \/>\n<meta property=\"og:description\" content=\"Uma explica\u00e7\u00e3o simples de como agrupar e agregar m\u00faltiplas colunas em um DataFrame do pandas, incluindo exemplos.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/\" \/>\n<meta property=\"og:site_name\" content=\"Statorials\" \/>\n<meta property=\"article:published_time\" content=\"2023-07-28T02:29:34+00:00\" \/>\n<meta name=\"author\" content=\"Dr. benjamim anderson\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Dr. benjamim anderson\" \/>\n\t<meta name=\"twitter:label2\" content=\"Tempo estimado de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/\",\"url\":\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/\",\"name\":\"Pandas: como agrupar e agregar em v\u00e1rias colunas\",\"isPartOf\":{\"@id\":\"https:\/\/statorials.org\/pt\/#website\"},\"datePublished\":\"2023-07-28T02:29:34+00:00\",\"dateModified\":\"2023-07-28T02:29:34+00:00\",\"author\":{\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666\"},\"description\":\"Uma explica\u00e7\u00e3o simples de como agrupar e agregar m\u00faltiplas colunas em um DataFrame do pandas, incluindo exemplos.\",\"breadcrumb\":{\"@id\":\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/#breadcrumb\"},\"inLanguage\":\"pt-PT\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Lar\",\"item\":\"https:\/\/statorials.org\/pt\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Pandas: como agrupar e agregar em v\u00e1rias colunas\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/statorials.org\/pt\/#website\",\"url\":\"https:\/\/statorials.org\/pt\/\",\"name\":\"Statorials\",\"description\":\"O seu guia para a literacia estat\u00edstica!\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/statorials.org\/pt\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pt-PT\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666\",\"name\":\"Dr. benjamim anderson\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-PT\",\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg\",\"contentUrl\":\"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg\",\"caption\":\"Dr. benjamim anderson\"},\"description\":\"Ol\u00e1, sou Benjamin, um professor aposentado de estat\u00edstica que se tornou professor dedicado na Statorials. Com vasta experi\u00eancia e conhecimento na \u00e1rea de estat\u00edstica, estou empenhado em compartilhar meu conhecimento para capacitar os alunos por meio de Statorials. Saber mais\",\"sameAs\":[\"https:\/\/statorials.org\/pt\"]}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Pandas: como agrupar e agregar em v\u00e1rias colunas","description":"Uma explica\u00e7\u00e3o simples de como agrupar e agregar m\u00faltiplas colunas em um DataFrame do pandas, incluindo exemplos.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/","og_locale":"pt_PT","og_type":"article","og_title":"Pandas: como agrupar e agregar em v\u00e1rias colunas","og_description":"Uma explica\u00e7\u00e3o simples de como agrupar e agregar m\u00faltiplas colunas em um DataFrame do pandas, incluindo exemplos.","og_url":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/","og_site_name":"Statorials","article_published_time":"2023-07-28T02:29:34+00:00","author":"Dr. benjamim anderson","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"Dr. benjamim anderson","Tempo estimado de leitura":"2 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/","url":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/","name":"Pandas: como agrupar e agregar em v\u00e1rias colunas","isPartOf":{"@id":"https:\/\/statorials.org\/pt\/#website"},"datePublished":"2023-07-28T02:29:34+00:00","dateModified":"2023-07-28T02:29:34+00:00","author":{"@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666"},"description":"Uma explica\u00e7\u00e3o simples de como agrupar e agregar m\u00faltiplas colunas em um DataFrame do pandas, incluindo exemplos.","breadcrumb":{"@id":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/#breadcrumb"},"inLanguage":"pt-PT","potentialAction":[{"@type":"ReadAction","target":["https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/statorials.org\/pt\/pandas-groupby-agrega-multiplas-colunas\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Lar","item":"https:\/\/statorials.org\/pt\/"},{"@type":"ListItem","position":2,"name":"Pandas: como agrupar e agregar em v\u00e1rias colunas"}]},{"@type":"WebSite","@id":"https:\/\/statorials.org\/pt\/#website","url":"https:\/\/statorials.org\/pt\/","name":"Statorials","description":"O seu guia para a literacia estat\u00edstica!","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/statorials.org\/pt\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pt-PT"},{"@type":"Person","@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666","name":"Dr. benjamim anderson","image":{"@type":"ImageObject","inLanguage":"pt-PT","@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/image\/","url":"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg","contentUrl":"https:\/\/statorials.org\/pt\/wp-content\/uploads\/2023\/10\/Dr.-Benjamin-Anderson-96x96.jpg","caption":"Dr. benjamim anderson"},"description":"Ol\u00e1, sou Benjamin, um professor aposentado de estat\u00edstica que se tornou professor dedicado na Statorials. Com vasta experi\u00eancia e conhecimento na \u00e1rea de estat\u00edstica, estou empenhado em compartilhar meu conhecimento para capacitar os alunos por meio de Statorials. Saber mais","sameAs":["https:\/\/statorials.org\/pt"]}]}},"yoast_meta":{"yoast_wpseo_title":"","yoast_wpseo_metadesc":"","yoast_wpseo_canonical":""},"_links":{"self":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts\/983","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/comments?post=983"}],"version-history":[{"count":0,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts\/983\/revisions"}],"wp:attachment":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/media?parent=983"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/categories?post=983"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/tags?post=983"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}