Domine a Visualização de Dados com Matplotlib em Python

Introdução ao Matplotlib

O Matplotlib é uma biblioteca de visualização de dados incrivelmente poderosa para a linguagem de programação Python. Amplamente reconhecida por sua versatilidade e eficiência, esta ferramenta é uma escolha popular entre cientistas de dados e entusiastas de machine learning. O Matplotlib permite criar uma vasta gama de gráficos estáticos, animados e interativos com apenas algumas linhas de código. Para quem está começando em machine learning, dominar o Matplotlib é fundamental para explorar conjuntos de dados e apresentar insights de forma clara e impactante.

Configuração Inicial no Google Colab

Para desfrutar dos recursos do Matplotlib no Google Colab, siga estes passos simples:

  1. Acesse o Google Colab e crie um novo notebook.
  2. No topo da célula do notebook, digite e execute o comando de importação:
  3. Verifique a instalação com:

Com o ambiente pronto, você pode começar a criar seus primeiros gráficos!

Aprenda Machine Learning em 5 Dias. Curso 100% Prático.
Melhor Preço por Tempo Limitado. Clique Aqui e Teste Sem Risco.
30 Dias de Satisfação Garantida!

 

Primeiros Passos com Matplotlib

Plotagem de um Gráfico de Dispersão (Scatter Plot)

O gráfico de dispersão é útil para visualizar a relação entre duas variáveis.

O gráfico de dispersão, ou scatter plot, é uma ferramenta fundamental na visualização de dados e é essencialmente utilizado para explorar a relação ou correlação entre duas variáveis numéricas. Aqui está um passo a passo do que acontece no bloco de código que gera um gráfico de dispersão utilizando a biblioteca Matplotlib em Python:

  1. Importação da Biblioteca:

    O primeiro passo é importar o módulo matplotlib.pyplot, geralmente abreviado para plt. Este módulo é uma coleção de funções que tornam o Matplotlib semelhante ao MATLAB, oferecendo uma interface simples para geração de gráficos.
  2. Definindo os Dados:

    Criamos duas listas: x e y, cada uma contendo uma sequência de números. No contexto do gráfico de dispersão, cada par de elementos correspondentes (x[i], y[i]) representa uma coordenada que será plotada no gráfico. A lista x geralmente representa a variável independente, enquanto a lista y representa a variável dependente.
  3. Utilização da Função scatter():

    Chamamos a função scatter() do módulo matplotlib.pyplot, que recebe os dados do eixo x e do eixo y e gera os pontos no gráfico de dispersão. Por padrão, cada ponto é representado por um marcador circular.
  4. Adicionando Títulos e Rótulos:

    A função title() é utilizada para adicionar um título ao gráfico. De forma similar, as funções xlabel() e ylabel() são usadas para adicionar rótulos aos eixos x e y, respectivamente. Essas legendas são importantes pois ajudam na interpretação dos dados, facilitando o entendimento do que cada eixo representa.
  5. Exibição do Gráfico:

    Por fim, a função show() é chamada para exibir a figura criada. Quando esta função é executada, uma janela com o gráfico de dispersão é aberta, permitindo a visualização dos pontos que foram plotados.

Este código produz um gráfico simples e claro que mostra a relação linear entre as listas x e y. Através deste gráfico, é possível identificar visualmente tendências, padrões e até mesmo outliers (pontos que se desviam significativamente da tendência dos demais dados).

Plotar um gráfico de dispersão (Scatter Plot) é uma excelente forma de visualizar a distribuição e relação entre duas variáveis. No contexto dos principais Cloud Providers Mundiais, podemos usar um gráfico de dispersão para comparar, por exemplo, a receita global e o crescimento ano a ano dessas empresas. Vamos criar um exemplo um pouco mais complexo que analisa essas métricas.

Preparando os Dados

Suponha que temos os seguintes dados para os Cloud Providers:

Aqui, cloud_providers é uma lista de nomes dos fornecedores de nuvem, receita representa a receita anual mais recente de cada um (em bilhões de dólares), e crescimento é o crescimento percentual de receita ano a ano para cada fornecedor.

Plotagem do Gráfico de Dispersão

Vamos plotar os dados em um gráfico de dispersão e adicionar algumas personalizações:

Neste gráfico de dispersão, utilizamos um loop for para iterar sobre as listas de receita e crescimento, plotando cada ponto individualmente. Cada fornecedor de nuvem é representado por um ponto no gráfico, cuja posição é determinada pelo seu valor de receita e crescimento. O tamanho do ponto (s=100) é uniforme para todos, enquanto o parâmetro alpha regula a transparência dos pontos, permitindo melhor visualização caso haja sobreposição. A legenda é importante para identificar cada ponto com seu respectivo fornecedor.

Esse gráfico é útil para stakeholders e analistas de mercado que desejam entender rapidamente como cada fornecedor está posicionado em termos de receita e crescimento. Insights como “o fornecedor com maior receita também é o que cresce mais rápido?” ou “há fornecedores menores com taxas de crescimento altas?” podem ser facilmente obtidos a partir desta visualização.

Ao plotar um gráfico de dispersão (Scatter Plot), a intenção é muitas vezes identificar visualmente qualquer correlação entre duas variáveis numéricas. A presença de padrões, a direção e a densidade dos pontos podem sugerir diferentes tipos de relações. Vamos criar um exemplo que ilustra claramente como esse tipo de gráfico pode ser utilizado para explicar a relação e correlação entre variáveis numéricas.

Exemplo: Relação entre Horas de Estudo e Pontuação em um Teste

Suponha que temos um conjunto de dados que inclui as horas gastas estudando e as pontuações obtidas em um teste por um grupo de estudantes:

A variável horas_estudo representa a quantidade de tempo que cada estudante gastou estudando, enquanto pontuacao_teste é a pontuação que cada um obteve no teste.

Plotando o Gráfico de Dispersão

Vamos criar um gráfico de dispersão para essas duas variáveis e adicionar uma linha de tendência para ajudar a visualizar a correlação:

Neste gráfico, cada ponto representa um estudante, com o eixo X mostrando as horas de estudo e o eixo Y as pontuações no teste. A linha vermelha pontilhada é a linha de tendência, que foi calculada usando uma função de ajuste polinomial (np.polyfit() e np.poly1d()), indicando a direção geral da correlação entre as variáveis.

  1. Cálculo da linha de tendência:
    • z = np.polyfit(horas_estudo, pontuacao_teste, 1): A função np.polyfit() da biblioteca NumPy é utilizada para ajustar um polinômio de grau especificado (neste caso, 1, indicando um polinômio linear) aos dados fornecidos. Ela retorna os coeficientes do polinômio que melhor se ajusta aos dados, no sentido dos mínimos quadrados. Para um polinômio de grau 1, z conterá dois valores: a inclinação da linha (slope) e o intercepto y (intercept).
    • p = np.poly1d(z): Após obter os coeficientes, np.poly1d() é utilizado para criar um objeto polinomial p a partir dos coeficientes z. Este objeto é uma função que pode ser chamada com um valor de x (neste caso, horas_estudo), retornando o valor de y correspondente na linha de tendência calculada.
  2. Desenho da linha de tendência no gráfico:
    • plt.plot(horas_estudo, p(horas_estudo), "r--"): Esta linha utiliza a função plt.plot() para desenhar a linha de tendência no gráfico. horas_estudo é usado como o eixo x, e p(horas_estudo) calcula os valores correspondentes no eixo y usando a função polinomial p criada anteriormente. "r--" define o estilo da linha de tendência, onde "r" significa vermelho e "--" indica que a linha será tracejada.

Este processo é essencial para análise de dados e visualização, pois a linha de tendência ajuda a entender a relação entre as variáveis analisadas. No contexto deste código, a linha de tendência mostra como a pontuação do teste tende a variar com o número de horas estudadas. Se a inclinação da linha for positiva, indica que há uma tendência de aumento na pontuação com o aumento das horas de estudo. Uma inclinação negativa indicaria o contrário. A visualização dessa relação em um gráfico ajuda não apenas a entender os dados atuais, mas também a fazer previsões sobre dados futuros dentro do mesmo contexto.

Interpretação da Correlação

Ao observar o gráfico, podemos ver que há um padrão ascendente nos pontos: quanto mais horas de estudo, maior a pontuação no teste, o que sugere uma correlação positiva entre as duas variáveis. A linha de tendência reforça visualmente essa relação. Essa informação é valiosa, por exemplo, para professores que querem enfatizar a importância do estudo na melhora do desempenho dos alunos.

Gráficos de dispersão são, portanto, ferramentas poderosas que ajudam a identificar tendências e padrões, possibilitando inferências sobre a força e a direção da relação entre variáveis numéricas, elementos fundamentais em campos como estatística, ciência de dados e pesquisa em geral.

Criação de um Gráfico de Barras (Bar Chart)

Ideal para comparar diferentes grupos.

O gráfico de barras é uma forma de representação gráfica que é utilizada para comparar valores entre diferentes categorias. É composto por barras, que podem ser exibidas horizontal ou verticalmente, e é particularmente útil quando se quer comparar várias categorias de dados entre si. Vamos detalhar o que acontece neste exemplo específico de código que cria um gráfico de barras utilizando o Matplotlib:

  1. Definição das Categorias e Valores:

    Aqui, duas listas são definidas: categorias e valores. A lista categorias contém rótulos de texto que representam as diferentes categorias a serem comparadas no gráfico. A lista valores contém números que correspondem ao tamanho ou medida de cada categoria.
  2. Criação do Gráfico de Barras:

    A função bar() é utilizada para desenhar o gráfico de barras. Os rótulos das categorias são passados como o primeiro argumento, e os respectivos valores são o segundo argumento. Esta função irá automaticamente associar cada valor com sua categoria correspondente e exibir as barras no gráfico com alturas proporcionais aos valores fornecidos.
  3. Adicionando Título ao Gráfico:

    A função title() adiciona um título ao gráfico. Títulos são cruciais para fornecer ao leitor uma rápida compreensão do que o gráfico está apresentando.
  4. Visualização do Gráfico:

    Por fim, show() é a função que renderiza e exibe o gráfico. Quando essa função é chamada, uma janela é aberta mostrando o gráfico de barras com as categorias no eixo x e os valores representados pelas alturas das barras no eixo y.

O gráfico de barras gerado a partir deste código facilita a comparação imediata entre as quatro categorias distintas, permitindo a visualização rápida de qual categoria possui o maior ou menor valor. É uma ferramenta visual extremamente eficaz para destacar diferenças entre grupos e é amplamente utilizado em relatórios de negócios, pesquisa acadêmica e, claro, na área de machine learning e análise de dados, para obter insights dos dados categóricos.

Gráficos de barras são excelentes para comparar visualmente quantidades em diferentes categorias e podem revelar de maneira clara as diferenças entre elas. Vamos criar um exemplo de um gráfico de barras que destaca a utilidade dessa ferramenta no mundo prático, por exemplo, ao comparar a receita gerada por diferentes filiais de uma empresa.

Exemplo: Receita Anual por Filial

Imagine que uma empresa possui cinco filiais e deseja visualizar a receita de cada uma no último ano para tomar decisões estratégicas. Aqui estão os dados:

As filiais são as categorias, e os valores em receita representam a receita anual em milhares de dólares para cada uma.

Plotagem do Gráfico de Barras

Agora, vamos plotar um gráfico de barras para visualizar essas informações:

Neste gráfico, cada barra representa uma filial, e a altura da barra é proporcional à receita anual da filial correspondente. A escolha de uma cor suave como ‘skyblue' permite que os olhos do espectador se concentrem nas diferenças de altura das barras, enquanto a borda ‘black' ajuda a definir cada barra claramente.

Interpretação do Gráfico de Barras

A visualização clara das diferenças de altura entre as barras permite que gestores identifiquem imediatamente a filial com maior e menor receita. No nosso exemplo, é evidente que a ‘Filial D' supera significativamente as outras em termos de receita, o que pode suscitar perguntas sobre as estratégias bem-sucedidas implementadas nesta filial e como elas podem ser aplicadas nas outras. Por outro lado, a ‘Filial C' poderia ser um ponto de foco para investigação e melhorias.

O gráfico de barras aqui demonstra sua utilidade prática ao destacar as diferenças entre as categorias de uma maneira que é fácil e rápida de compreender, fornecendo uma base sólida para análises e decisões empresariais subsequentes.

Elaboração de um Histograma (Histogram)

Um histograma é um tipo de gráfico que permite visualizar a distribuição de frequências de um conjunto de dados.

Exemplo 1: Distribuição de Idades em um Local de Trabalho

Para criar um exemplo mais realista, vamos considerar a distribuição das idades dos funcionários em uma empresa de médio porte. Este é um exemplo de uso prático onde um histograma pode ajudar a visualizar a diversidade de idades e planejar iniciativas como programas de treinamento, aposentadoria ou recrutamento.

Neste caso, temos um conjunto de idades que representam os funcionários da empresa:

Criando um Histograma

Com esses dados, podemos plotar um histograma que ilustrará a distribuição das idades:

A definição dos ‘bins' corresponde a faixas etárias de dez anos, facilitando a interpretação das principais faixas etárias na empresa. A cor ‘dodgerblue' é vibrante e torna as barras claramente visíveis, enquanto a borda ‘black' separa bem cada categoria de idade.

Este histograma fornece insights valiosos para o RH sobre a composição etária da força de trabalho. Ao examinar a altura das barras, a empresa pode identificar se possui uma população jovem, um equilíbrio de gerações, ou um grupo predominantemente sênior.

Usando os Dados para Planejamento Estratégico

Por exemplo, uma alta frequência de funcionários nas faixas mais jovens pode indicar a necessidade de programas de desenvolvimento de carreira para cultivar talentos a longo prazo. Por outro lado, se a maioria dos funcionários estiver nas faixas de maior idade, estratégias de planejamento sucessório e transmissão de conhecimento podem ser vitais.

O histograma, neste caso, é uma ferramenta poderosa de visualização que capacita os gestores a tomar decisões informadas sobre gestão de talentos e estratégias organizacionais, alinhando os esforços de recursos humanos com os objetivos a longo prazo da empresa.

Exemplo 2: Visualizando os Tempos de Resposta do Website com Histograma

Analisar os tempos de resposta de um website é essencial para compreender a experiência do usuário. Vamos criar um histograma baseado em uma simulação de dados que representam os tempos médios de resposta a cada hora em um dia.

Neste código Python, utilizamos a biblioteca numpy para gerar 24 dados que simulam os tempos de resposta do website em um período de 24 horas. Substituímos aleatoriamente 5 desses dados para representar tempos de resposta superiores a 1 segundo, o que pode indicar uma experiência de usuário prejudicada.

Ao executar este script, obtemos um histograma que representa a distribuição dos tempos de resposta do website. A linha vertical vermelha em x=1 é um marcador visual significativo; ela divide o gráfico entre tempos de resposta que são considerados aceitáveis (menos de 1 segundo) e aqueles que podem comprometer a experiência do usuário (mais de 1 segundo).

Os picos no histograma indicam os intervalos de tempo de resposta mais frequentes. A cor ‘skyblue' fornece um contraste efetivo com a linha vermelha, destacando a região do gráfico onde os tempos de resposta excedem o limiar crítico de 1 segundo.

Esse tipo de visualização é inestimável para a equipe de TI ou de operações de um website, pois ajuda a identificar os períodos em que o desempenho do website precisa ser melhorado. Uma maior frequência de tempos acima de 1 segundo pode ser um indicador para possíveis intervenções, como otimização de código, aumento de recursos de servidor ou a implementação de soluções de cache mais eficientes.

Portanto, ao utilizar um histograma para visualizar os tempos de resposta do website, a equipe responsável pode agir proativamente para assegurar que o website opere dentro dos padrões ideais, mantendo os usuários satisfeitos com uma navegação rápida e eficaz.

Desenho de um Gráfico de Linhas (Line Graph)

Perfeito para visualizar tendências ao longo do tempo.

O gráfico de linhas é uma das formas mais diretas e eficazes para representar tendências e mudanças ao longo do tempo ou para visualizar relações contínuas entre variáveis. É utilizado em uma ampla gama de campos, desde finanças até ciências naturais, pela sua capacidade de mostrar a evolução dos dados de forma clara e compreensível. Vamos explorar cada etapa do processo de criação de um gráfico de linhas usando o Matplotlib:

  1. Definição dos Dados das Coordenadas X e Y:

    Criamos uma sequência de números (de 0 a 9, neste caso) que serão usados como pontos no eixo X. Para os valores correspondentes do eixo Y, aplicamos uma operação (neste exemplo, a potência quadrada) para cada valor em X. O resultado é uma lista de valores Y que mostra uma tendência crescente – cada valor de Y é o quadrado de seu correspondente X.
  2. Plotagem do Gráfico de Linhas:

    A função plot() é chamada para desenhar o gráfico de linhas. A função conecta os pontos definidos pelos valores de X e Y com linhas, criando uma representação gráfica da relação entre essas duas variáveis.
  3. Adição de um Título ao Gráfico:

    A função title() adiciona um título descritivo ao gráfico de linhas. Isso fornece um contexto adicional e ajuda os observadores a entenderem rapidamente o que o gráfico está demonstrando.
  4. Exibição do Gráfico:

    O método show() é usado para exibir a figura gerada. Quando chamado, ele abre uma janela gráfica que mostra o gráfico de linhas, com os pontos conectados por linhas, exibindo a relação entre os eixos X e Y.

Este gráfico de linhas em particular ilustra uma relação quadrática entre X e Y, mostrando que, conforme X aumenta, Y aumenta numa taxa que se acelera (por ser o quadrado de X).

Gráficos de linhas como esse são extremamente úteis para análise de tendências, pois as linhas suavizam variações pontuais e destacam a direção em que os dados estão se movendo. Em machine learning, gráficos de linhas são frequentemente usados para avaliar o desempenho dos algoritmos ao longo de várias iterações de treinamento, e em análise de dados, para visualizar séries temporais e outras tendências contínuas nos dados.

Integração com Pandas para Visualização de Dados

Matplotlib e Pandas formam uma combinação poderosa para visualizar dados diretamente de DataFrames.

A biblioteca Pandas, em conjunto com o Matplotlib, oferece recursos sofisticados para a visualização de dados que estão estruturados em DataFrames, uma estrutura de dados bidimensional e versátil do Pandas. A capacidade de criar visualizações a partir de DataFrames sem a necessidade de extração prévia de informações simplifica o processo de análise de dados. Exploraremos como funciona essa integração:

  1. Importação da Biblioteca Pandas:

    Pandas é uma biblioteca do Python que fornece estruturas de dados de alto desempenho e fáceis de usar, juntamente com ferramentas de análise de dados. Começamos importando essa biblioteca para poder usar seus recursos de maneira eficaz.
  2. Criação do DataFrame com Dados Financeiros:

    Aqui, um dicionário com duas chaves (‘Ano' e ‘Lucro') e uma lista de valores associados é convertido em um DataFrame, que é uma das estruturas de dados centrais do Pandas. Cada chave do dicionário torna-se uma coluna no DataFrame, e a lista de valores associada a cada chave torna-se as linhas correspondentes a essa coluna.
  3. Visualização dos Dados Financeiros com Plot:

    O método plot() do DataFrame é utilizado para gerar o gráfico de linhas. Especificamos que a coluna ‘Ano' deve ser usada para o eixo X e ‘Lucro' para o eixo Y. O argumento kind='line' informa que queremos um gráfico de linhas.
  4. Exibição do Gráfico de Linhas:

    Ao chamarmos plt.show(), o Matplotlib renderiza o gráfico de linhas, exibindo a tendência do lucro ao longo dos anos especificados.
  5. Criação do DataFrame com Dados Climáticos:

    Similarmente, outro DataFrame é criado, desta vez contendo dados climáticos de temperatura.
  6. Visualização dos Dados Climáticos com Histograma:

    Para a visualização da distribuição de temperaturas, utilizamos o método hist(), que cria um histograma para a coluna ‘Temperatura'. O parâmetro bins=3 especifica que queremos que os dados sejam agrupados em 3 intervalos.
  7. Exibição do Histograma:

    Novamente, plt.show() é chamado para mostrar o gráfico, desta vez um histograma das temperaturas registradas.

A integração do Matplotlib com o Pandas torna o processo de visualização de dados altamente intuitivo e eficiente. Com apenas algumas linhas de código, é possível criar gráficos de linhas, histogramas e muitos outros tipos de visualizações diretamente de um DataFrame, permitindo que os analistas e cientistas de dados se concentrem em extrair insights significativos dos dados, ao invés de se preocuparem com detalhes técnicos de plotagem de gráficos.

Design de Gráficos

O design eficaz de gráficos é uma ferramenta poderosa para aprimorar a comunicação de dados complexos. Aqui estão dois exemplos práticos de como podemos personalizar gráficos para diferentes conjuntos de dados, tornando-os visualmente atraentes e informativos:

Exemplo 1: Desempenho de Vendas ao Longo do Ano

Consideremos um conjunto de dados que representa as vendas mensais de uma empresa:

Aqui, meses são os dados para o eixo X, e vendas são os dados para o eixo Y. Agora, vamos personalizar o gráfico de linhas:

Neste gráfico, a cor verde simboliza crescimento, e os marcadores em forma de círculo (‘o') em cada ponto de dados ajudam a destacar as vendas de cada mês. A linha contínua (‘-‘) conecta os pontos, mostrando a tendência de crescimento ao longo do ano.

Exemplo 2: Comparação do Crescimento de Três Produtos

Agora, imaginemos que queremos comparar o crescimento de vendas de três produtos diferentes ao longo do tempo:

Cada lista representa as vendas de um produto em diferentes trimestres. Agora, vamos criar um gráfico de linhas para cada produto:

Cada linha tem uma cor distinta, um estilo diferente (sólida, tracejada, pontilhada), e marcadores distintos (quadrado, triângulo, losango) para representar visualmente a trajetória de vendas de cada produto. O gráfico personalizado facilita a comparação do desempenho dos produtos de um olhar e permite que a audiência identifique rapidamente padrões e tendências.

Através desses dois exemplos, fica evidente como a personalização no design de gráficos pode enriquecer a história que os dados contam e reforçar as conclusões que desejamos destacar. Ao optarmos por cores, estilos de linhas e marcadores, criamos uma narrativa visual que não apenas capta a atenção mas também facilita o entendimento.

A Interface Orientada a Objetos do Matplotlib: Mais Controle de Seus Gráficos

Quando se trata de criar visualizações de dados personalizadas, a interface orientada a objetos (OO) do Matplotlib oferece um nível de controle que supera em muito a simplicidade do pyplot. Esta abordagem permite não apenas criar gráficos mais complexos, mas também gerenciá-los de maneira mais eficiente, especialmente quando estamos lidando com múltiplas visualizações em uma única figura.

Considere o seguinte exemplo que ilustra a flexibilidade da interface OO do Matplotlib:

Ao usar a função plt.subplots(1, 2, figsize=(10, 4)), nós efetivamente indicamos ao Matplotlib que queremos uma figura com uma linha e duas colunas de subplots, juntamente com um tamanho específico definido pelo figsize. Isso nos dá uma tela dividida em duas áreas de gráfico distintas, referenciadas pelas variáveis ax1 e ax2.

Com ax1.scatter() e ax2.plot(), cada gráfico é criado de forma independente dentro de sua respectiva área. Isso nos permite não apenas escolher diferentes tipos de gráficos para representar nossos dados, mas também ajustar títulos, rótulos dos eixos e outros elementos estéticos de forma individualizada. Por exemplo, um gráfico pode ser de dispersão enquanto o outro pode mostrar a evolução dos dados através de uma linha, facilitando a comparação e a análise conjunta dos dados.

Esse nível de detalhe e personalização é um poderoso recurso para quem precisa comunicar informações complexas de maneira clara e precisa, seja em relatórios, artigos científicos ou apresentações de negócios.

Portanto, dominar a interface orientada a objetos do Matplotlib é uma habilidade valiosa para qualquer pessoa que trabalha com análise de dados. Ela possibilita a construção de visualizações de dados que são ao mesmo tempo informativas e esteticamente agradáveis, proporcionando uma compreensão mais profunda dos dados representados.

Vamos a mais um exemplo. Suponha que queremos criar uma figura que contenha um gráfico de barras e um de linha, ilustrando diferentes tipos de dados que possuem algum tipo de relação. Por exemplo, podemos estar interessados em mostrar vendas de um produto (gráfico de barras) e a satisfação do cliente (gráfico de linha) ao longo do mesmo período de tempo.

Aqui está como poderíamos fazer isso:

Neste exemplo, o objeto ax1 é usado para plotar o gráfico de barras e o objeto ax2 é criado com a chamada ax1.twinx(), o que significa que ax2 é um novo conjunto de eixos que compartilha o eixo x com ax1, mas tem um eixo y independente. Isso é particularmente útil quando temos variáveis com diferentes escalas de medida.

No gráfico de barras (ax1.bar), as vendas são representadas como barras verdes, com seus valores no eixo y à esquerda. No gráfico de linha (ax2.plot), a satisfação do cliente é representada por uma linha azul, com seus valores no eixo y à direita.

Essa combinação de diferentes tipos de gráficos em uma única figura permite que o público-alvo compreenda facilmente a relação entre as duas variáveis, fornecendo uma comparação visual direta em uma única vista.

Utilizando a interface orientada a objetos, você tem controle total sobre cada aspecto dos seus gráficos, permitindo-lhe criar visualizações precisas e de alto impacto para seus dados.

Explorar a fundo o Matplotlib abre um mundo de possibilidades em análise e apresentação de dados. Para iniciantes em Python e machine learning, desenvolver habilidades no uso desta biblioteca é um passo significativo no caminho para se tornarem cientistas de dados proficientes.

Não esqueça de consultar a documentação oficial do Matplotlib e buscar outros recursos como tutoriais e comunidades online para aprofundar seus conhecimentos.

Cada exemplo neste artigo é apenas o início de sua aventura com visualização de dados. Com prática e curiosidade, você logo estará criando gráficos dinâmicos e insights valiosos a partir dos seus conjuntos de dados. Boa sorte na sua jornada de aprendizado!

Scroll to Top