{"id":1326,"date":"2023-07-26T20:57:06","date_gmt":"2023-07-26T20:57:06","guid":{"rendered":"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/"},"modified":"2023-07-26T20:57:06","modified_gmt":"2023-07-26T20:57:06","slug":"pandas-rolantes-do-mal","status":"publish","type":"post","link":"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/","title":{"rendered":"Como calcular uma m\u00e9dia m\u00f3vel em pandas"},"content":{"rendered":"<p><\/p>\n<hr>\n<p><span style=\"color: #000000;\">Uma <strong>m\u00e9dia m\u00f3vel<\/strong> \u00e9 simplesmente a m\u00e9dia de v\u00e1rios per\u00edodos anteriores em uma s\u00e9rie temporal.<\/span><\/p>\n<p> <span style=\"color: #000000;\">Para calcular a m\u00e9dia m\u00f3vel de uma ou mais colunas em um DataFrame do pandas, podemos usar a seguinte sintaxe:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong>df[' <span style=\"color: #008000;\">column_name<\/span> ']. <span style=\"color: #3366ff;\">rolling<\/span> ( <span style=\"color: #008000;\">rolling_window<\/span> ). <span style=\"color: #3366ff;\">mean<\/span> ()\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">Este tutorial fornece v\u00e1rios exemplos de uso pr\u00e1tico desta fun\u00e7\u00e3o.<\/span><\/p>\n<h3> <span style=\"color: #000000;\"><strong>Exemplo: calculando a m\u00e9dia m\u00f3vel em pandas<\/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: #008000;\">import<\/span> numpy <span style=\"color: #008000;\">as<\/span> np\n<span style=\"color: #008000;\">import<\/span> pandas <span style=\"color: #008000;\">as<\/span> pd\n\n<span style=\"color: #008080;\">#make this example reproducible\n<\/span>n.p. <span style=\"color: #3366ff;\">random<\/span> . <span style=\"color: #3366ff;\">seeds<\/span> (0)\n\n<span style=\"color: #008080;\">#create dataset<\/span>\nperiod = np. <span style=\"color: #3366ff;\">arange<\/span> (1, 101, 1)\nleads = np. <span style=\"color: #3366ff;\">random<\/span> . <span style=\"color: #3366ff;\">uniform<\/span> (1, 20, 100)\nsales = 60 + 2*period + np. <span style=\"color: #3366ff;\">random<\/span> . <span style=\"color: #3366ff;\">normal<\/span> (loc=0, scale=.5*period, size=100)\ndf = pd. <span style=\"color: #3366ff;\">DataFrame<\/span> ({' <span style=\"color: #008000;\">period<\/span> ': period, ' <span style=\"color: #008000;\">leads<\/span> ': leads, ' <span style=\"color: #008000;\">sales<\/span> ': sales})\n\n<span style=\"color: #008080;\">#view first 10 rows\n<\/span>df. <span style=\"color: #3366ff;\">head<\/span> (10)\n\n   period leads sales\n0 1 11.427457 61.417425\n1 2 14.588598 64.900826\n2 3 12.452504 66.698494\n3 4 11.352780 64.927513\n4 5 9.049441 73.720630\n5 6 13.271988 77.687668\n6 7 9.314157 78.125728\n7 8 17.943687 75.280301\n8 9 19.309592 73.181613\n9 10 8.285389 85.272259\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">Podemos usar a seguinte sintaxe para criar uma nova coluna contendo a m\u00e9dia m\u00f3vel de \u201cvendas\u201d dos 5 per\u00edodos anteriores:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008080;\">#find rolling mean of previous 5 sales periods\n<\/span>df[' <span style=\"color: #008000;\">rolling_sales_5<\/span> '] = df[' <span style=\"color: #008000;\">sales<\/span> ']. <span style=\"color: #3366ff;\">rolling<\/span> (5). <span style=\"color: #3366ff;\">mean<\/span> ()\n\n<span style=\"color: #008080;\">#view first 10 rows\n<\/span>df. <span style=\"color: #3366ff;\">head<\/span> (10)\n\n\tperiod leads sales rolling_sales_5\n0 1 11.427457 61.417425 NaN\n1 2 14.588598 64.900826 NaN\n2 3 12.452504 66.698494 NaN\n3 4 11.352780 64.927513 NaN\n4 5 9.049441 73.720630 66.332978\n5 6 13.271988 77.687668 69.587026\n6 7 9.314157 78.125728 72.232007\n7 8 17.943687 75.280301 73.948368\n8 9 19.309592 73.181613 75.599188\n9 10 8.285389 85.272259 77.909514\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">Podemos verificar manualmente que a m\u00e9dia m\u00f3vel de vendas exibida para o per\u00edodo 5 \u00e9 a m\u00e9dia dos 5 per\u00edodos anteriores:<\/span><\/p>\n<p> <span style=\"color: #000000;\">M\u00e9dia m\u00f3vel no per\u00edodo 5: (61,417+64,900+66,698+64,927+73,720)\/5 = <strong>66,33<\/strong><\/span><\/p>\n<p> <span style=\"color: #000000;\">Podemos usar sintaxe semelhante para calcular a m\u00e9dia m\u00f3vel de m\u00faltiplas colunas:<\/span><\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008080;\">#find rolling mean of previous 5 leads periods \n<span style=\"color: #000000;\">df[' <span style=\"color: #008000;\">rolling_leads_5<\/span> '] = df[' <span style=\"color: #008000;\">leads<\/span> ']. <span style=\"color: #3366ff;\">rolling<\/span> (5). <span style=\"color: #3366ff;\">mean<\/span> ()<\/span>\n\n#find rolling mean of previous 5 leads periods\n<\/span>df[' <span style=\"color: #008000;\">rolling_sales_5<\/span> '] = df[' <span style=\"color: #008000;\">sales<\/span> ']. <span style=\"color: #3366ff;\">rolling<\/span> (5). <span style=\"color: #3366ff;\">mean<\/span> ()\n\n<span style=\"color: #008080;\">#view first 10 rows\n<\/span>df. <span style=\"color: #3366ff;\">head<\/span> (10)\n\n\tperiod leads sales rolling_sales_5 rolling_leads_5\n0 1 11.427457 61.417425 NaN NaN\n1 2 14.588598 64.900826 NaN NaN\n2 3 12.452504 66.698494 NaN NaN\n3 4 11.352780 64.927513 NaN NaN\n4 5 9.049441 73.720630 66.332978 11.774156\n5 6 13.271988 77.687668 69.587026 12.143062\n6 7 9.314157 78.125728 72.232007 11.088174\n7 8 17.943687 75.280301 73.948368 12.186411\n8 9 19.309592 73.181613 75.599188 13.777773\n9 10 8.285389 85.272259 77.909514 13.624963\n<\/strong><\/pre>\n<p> <span style=\"color: #000000;\">Tamb\u00e9m podemos criar um gr\u00e1fico de linha r\u00e1pido usando Matplotlib para visualizar as vendas brutas versus a m\u00e9dia m\u00f3vel de vendas:<\/span> <\/p>\n<pre style=\"background-color: #ececec; font-size: 15px;\"> <strong><span style=\"color: #008080;\"><span style=\"color: #000000;\"><span style=\"color: #008000;\">import<\/span> matplotlib. <span style=\"color: #3366ff;\">pyplot<\/span> <span style=\"color: #008000;\">as<\/span> plt<\/span>\n<span style=\"color: #000000;\">plt. <span style=\"color: #3366ff;\">plot<\/span> (df[' <span style=\"color: #008000;\">rolling_sales_5<\/span> '], label=' <span style=\"color: #008000;\">Rolling Mean<\/span> ')<\/span>\n<span style=\"color: #000000;\">plt. <span style=\"color: #3366ff;\">plot<\/span> (df[' <span style=\"color: #008000;\">sales<\/span> '], label=' <span style=\"color: #008000;\">Raw Data<\/span> ')<\/span>\n<span style=\"color: #000000;\">plt. <span style=\"color: #3366ff;\">legend<\/span> ()<\/span>\n<span style=\"color: #000000;\">plt. <span style=\"color: #3366ff;\">ylabel<\/span> (' <span style=\"color: #008000;\">Sales<\/span> ')<\/span>\n<span style=\"color: #000000;\">plt. <span style=\"color: #3366ff;\">xlabel<\/span> (' <span style=\"color: #008000;\">Period<\/span> ')<\/span>\n<span style=\"color: #000000;\">plt. <span style=\"color: #3366ff;\">show<\/span> ()<\/span>\n<\/span><\/strong><\/pre>\n<p><img decoding=\"async\" loading=\"lazy\" class=\"aligncenter wp-image-12961\" src=\"https:\/\/statorials.org\/wp-content\/uploads\/2023\/08\/roulantmeanpandas1.png\" alt=\"Tra\u00e7ando a m\u00e9dia m\u00f3vel em pandas em Python\" width=\"387\" height=\"263\" srcset=\"\" sizes=\"auto, \"><\/p>\n<p> <span style=\"color: #000000;\">A linha azul mostra a m\u00e9dia m\u00f3vel de vendas de 5 per\u00edodos e a linha laranja mostra os dados brutos de vendas.<\/span><\/p>\n<h3> <strong>Recursos adicionais<\/strong><\/h3>\n<p> <span style=\"color: #000000;\">Os tutoriais a seguir explicam como realizar outras tarefas comuns em pandas:<\/span><\/p>\n<p> <a href=\"https:\/\/statorials.org\/pt\/rolamento-de-correlacao-de-pandas\/\" target=\"_blank\" rel=\"noopener\">Como calcular a correla\u00e7\u00e3o deslizante em pandas<\/a><br \/> <a href=\"https:\/\/statorials.org\/pt\/coluna-media-de-pandas\/\" target=\"_blank\" rel=\"noopener\">Como calcular a m\u00e9dia das colunas no Pandas<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Uma m\u00e9dia m\u00f3vel \u00e9 simplesmente a m\u00e9dia de v\u00e1rios per\u00edodos anteriores em uma s\u00e9rie temporal. Para calcular a m\u00e9dia m\u00f3vel de uma ou mais colunas em um DataFrame do pandas, podemos usar a seguinte sintaxe: df[&#8216; column_name &#8216;]. rolling ( rolling_window ). mean () Este tutorial fornece v\u00e1rios exemplos de uso pr\u00e1tico desta fun\u00e7\u00e3o. Exemplo: [&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-1326","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>Como calcular uma m\u00e9dia m\u00f3vel em Pandas \u2013 Statorials<\/title>\n<meta name=\"description\" content=\"Este tutorial explica como calcular uma m\u00e9dia m\u00f3vel para uma ou mais colunas em um DataFrame do pandas, com 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-rolantes-do-mal\/\" \/>\n<meta property=\"og:locale\" content=\"pt_PT\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Como calcular uma m\u00e9dia m\u00f3vel em Pandas \u2013 Statorials\" \/>\n<meta property=\"og:description\" content=\"Este tutorial explica como calcular uma m\u00e9dia m\u00f3vel para uma ou mais colunas em um DataFrame do pandas, com exemplos.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/\" \/>\n<meta property=\"og:site_name\" content=\"Statorials\" \/>\n<meta property=\"article:published_time\" content=\"2023-07-26T20:57:06+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/statorials.org\/wp-content\/uploads\/2023\/08\/roulantmeanpandas1.png\" \/>\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-rolantes-do-mal\/\",\"url\":\"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/\",\"name\":\"Como calcular uma m\u00e9dia m\u00f3vel em Pandas \u2013 Statorials\",\"isPartOf\":{\"@id\":\"https:\/\/statorials.org\/pt\/#website\"},\"datePublished\":\"2023-07-26T20:57:06+00:00\",\"dateModified\":\"2023-07-26T20:57:06+00:00\",\"author\":{\"@id\":\"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666\"},\"description\":\"Este tutorial explica como calcular uma m\u00e9dia m\u00f3vel para uma ou mais colunas em um DataFrame do pandas, com exemplos.\",\"breadcrumb\":{\"@id\":\"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/#breadcrumb\"},\"inLanguage\":\"pt-PT\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Lar\",\"item\":\"https:\/\/statorials.org\/pt\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Como calcular uma m\u00e9dia m\u00f3vel em pandas\"}]},{\"@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":"Como calcular uma m\u00e9dia m\u00f3vel em Pandas \u2013 Statorials","description":"Este tutorial explica como calcular uma m\u00e9dia m\u00f3vel para uma ou mais colunas em um DataFrame do pandas, com 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-rolantes-do-mal\/","og_locale":"pt_PT","og_type":"article","og_title":"Como calcular uma m\u00e9dia m\u00f3vel em Pandas \u2013 Statorials","og_description":"Este tutorial explica como calcular uma m\u00e9dia m\u00f3vel para uma ou mais colunas em um DataFrame do pandas, com exemplos.","og_url":"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/","og_site_name":"Statorials","article_published_time":"2023-07-26T20:57:06+00:00","og_image":[{"url":"https:\/\/statorials.org\/wp-content\/uploads\/2023\/08\/roulantmeanpandas1.png"}],"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-rolantes-do-mal\/","url":"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/","name":"Como calcular uma m\u00e9dia m\u00f3vel em Pandas \u2013 Statorials","isPartOf":{"@id":"https:\/\/statorials.org\/pt\/#website"},"datePublished":"2023-07-26T20:57:06+00:00","dateModified":"2023-07-26T20:57:06+00:00","author":{"@id":"https:\/\/statorials.org\/pt\/#\/schema\/person\/e08f98e8db95e0aa9c310e1b27c9c666"},"description":"Este tutorial explica como calcular uma m\u00e9dia m\u00f3vel para uma ou mais colunas em um DataFrame do pandas, com exemplos.","breadcrumb":{"@id":"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/#breadcrumb"},"inLanguage":"pt-PT","potentialAction":[{"@type":"ReadAction","target":["https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/statorials.org\/pt\/pandas-rolantes-do-mal\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Lar","item":"https:\/\/statorials.org\/pt\/"},{"@type":"ListItem","position":2,"name":"Como calcular uma m\u00e9dia m\u00f3vel em pandas"}]},{"@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\/1326","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=1326"}],"version-history":[{"count":0,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/posts\/1326\/revisions"}],"wp:attachment":[{"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/media?parent=1326"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/categories?post=1326"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/statorials.org\/pt\/wp-json\/wp\/v2\/tags?post=1326"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}