Construa Seu Primeiro Flow
Aprenda como criar fluxos de trabalho estruturados e orientados a eventos com controle preciso sobre a execução.
Assumindo o Controle de Workflows de IA com Flows
Os Flows do CrewAI representam o próximo nível em orquestração de IA – combinando o poder colaborativo de equipes de agentes de IA com a precisão e flexibilidade da programação procedural. Enquanto os crews se destacam em colaboração de agentes, os flows dão a você controle detalhado sobre exatamente como e quando diferentes componentes do seu sistema de IA interagem.
Neste guia, vamos percorrer a criação de um poderoso CrewAI Flow que gera um guia de aprendizado abrangente sobre qualquer tema. Este tutorial demonstrará como os Flows oferecem controle estruturado e orientado a eventos sobre seus workflows de IA ao combinar código regular, chamadas diretas a LLM e processamento baseado em crews.
O Que Torna os Flows Poderosos
Com flows, você pode:
- Combinar diferentes padrões de interação com IA – Use crews para tarefas colaborativas complexas, chamadas diretas às LLMs para operações mais simples, e código regular para lógica procedural.
- Construir sistemas orientados a eventos – Defina como os componentes respondem a eventos e mudanças de dados específicos.
- Manter estado entre componentes – Compartilhe e transforme dados entre diferentes partes da sua aplicação.
- Integrar com sistemas externos – Conecte seu fluxo de trabalho de IA com bancos de dados, APIs e interfaces de usuário de forma transparente.
- Criar caminhos de execução complexos – Projete ramificações condicionais, processamento paralelo e workflows dinâmicos.
O Que Você Vai Construir e Aprender
Ao final deste guia, você terá:
- Criado um sistema sofisticado de geração de conteúdo que combina entrada do usuário, planejamento por IA e criação de conteúdo multiagente.
- Orquestrado o fluxo de informações entre diferentes componentes do seu sistema.
- Implementado uma arquitetura orientada a eventos onde cada etapa responde à conclusão das etapas anteriores.
- Construído uma base para aplicações de IA mais complexas que você pode expandir e personalizar.
Este flow de criação de guia demonstra padrões fundamentais que podem ser aplicados para criar aplicações muito mais avançadas, como:
- Assistentes de IA interativos que combinam múltiplos subsistemas especializados.
- Pipelines de processamento de dados complexos com transformações aprimoradas por IA.
- Agentes autônomos integrados a serviços e APIs externas.
- Sistemas de tomada de decisão em múltiplas etapas com processos envolvendo humanos no loop.
Vamos começar e construir seu primeiro flow!
Pré-requisitos
Antes de começar, certifique-se de ter:
- Instalado o CrewAI seguindo o guia de instalação
- Configurado sua chave de API LLM no ambiente, conforme o guia de configuração do LLM
- Conhecimentos básicos de Python
Passo 1: Crie um Novo Projeto de CrewAI Flow
Primeiro, vamos criar um novo projeto de Flow do CrewAI usando a CLI. Este comando configura um projeto com todos os diretórios necessários e arquivos de template para seu flow.
Isso gerará um projeto com a estrutura básica necessária para seu flow.
Visão Geral do Framework CrewAI
Passo 2: Entendendo a Estrutura do Projeto
O projeto gerado possui a seguinte estrutura. Reserve um momento para conhecê-la, pois isso ajudará você a criar flows mais complexos no futuro.
Esta estrutura oferece uma separação clara entre os diferentes componentes do seu flow:
- A lógica principal do flow no arquivo
main.py
- Crews especializados no diretório
crews
- Ferramentas customizadas no diretório
tools
Vamos modificar esta estrutura para criar nosso flow de criação de guias, que irá orquestrar o processo de geração de guias de aprendizagem abrangentes.
Passo 3: Adicione um Crew de Redator de Conteúdo
Nosso flow precisará de um crew especializado para lidar com o processo de criação de conteúdo. Vamos usar a CLI do CrewAI para adicionar um crew de redatores de conteúdo:
Este comando cria automaticamente os diretórios e arquivos de template necessários para seu crew. O crew de redatores será responsável por escrever e revisar seções do nosso guia, trabalhando dentro do flow orquestrado pela aplicação principal.
Passo 4: Configure o Crew de Redator de Conteúdo
Agora, vamos modificar os arquivos gerados para o crew de redatores. Vamos configurar dois agentes especializados – um escritor e um revisor – que irão colaborar para criar um conteúdo de alta qualidade para o nosso guia.
-
Primeiro, atualize o arquivo de configuração de agents para definir a equipe de criação de conteúdo:
Lembre-se de configurar o
llm
com o provedor que está utilizando.
Essas definições de agents estabelecem papéis e perspectivas especializadas que irão moldar como nossos agentes de IA abordam a criação de conteúdo. Note como cada agent possui um propósito e expertise distintos.
- Em seguida, atualize o arquivo de configuração de tarefas para definir as tarefas específicas de escrita e revisão:
Essas definições de tarefas fornecem instruções detalhadas para nossos agents, garantindo que eles produzam conteúdo que atenda aos padrões de qualidade. Observe como o parâmetro context
na tarefa de revisão cria um fluxo onde o revisor tem acesso à produção do redator.
- Agora, atualize o arquivo de implementação do crew para definir como nossos agents e tasks trabalham juntos:
Essa definição de crew estabelece o relacionamento entre nossos agents e tasks, definindo um processo sequencial onde o redator cria o rascunho e o revisor o aprimora. Embora este crew possa funcionar de forma independente, em nosso flow ele será orquestrado como parte de um sistema maior.
Passo 5: Crie o Flow
Agora vem a parte emocionante – criar o flow que irá orquestrar todo o processo de criação do guia. Aqui iremos combinar código Python regular, chamadas diretas a LLM e nosso crew de criação de conteúdo em um sistema coeso.
Nosso flow irá:
- Obter a entrada do usuário sobre o tema e nível do público
- Fazer uma chamada direta à LLM para criar um roteiro estruturado do guia
- Processar cada seção sequencialmente usando o crew de redatores
- Combinar tudo em um documento final abrangente
Vamos criar nosso flow no arquivo main.py
:
Vamos analisar o que está acontecendo neste flow:
- Definimos modelos Pydantic para dados estruturados, garantindo segurança de tipos e representação clara dos dados.
- Criamos uma classe de estado para manter dados entre os diferentes passos do flow.
- Implementamos três etapas principais para o flow:
- Obtenção da entrada do usuário com o decorator
@start()
- Criação do roteiro do guia com uma chamada direta à LLM
- Processamento das seções com nosso crew de conteúdo
- Obtenção da entrada do usuário com o decorator
- Usamos o decorator
@listen()
para estabelecer relações orientadas a eventos entre as etapas
Este é o poder dos flows – combinar diferentes tipos de processamento (interação com usuário, chamadas diretas a IA, tarefas colaborativas com crews) em um sistema orientado a eventos e coeso.
Passo 6: Configure suas Variáveis de Ambiente
Crie um arquivo .env
na raiz do projeto com suas chaves de API. Veja o guia de configuração do LLM para detalhes sobre como configurar o provedor.
Passo 7: Instale as Dependências
Instale as dependências necessárias:
Passo 8: Execute Seu Flow
Agora é hora de ver seu flow em ação! Execute-o usando a CLI do CrewAI:
Quando você rodar esse comando, verá seu flow ganhando vida:
- Ele solicitará um tema e o nível do público para você
- Criará um roteiro estruturado para o seu guia
- Processará cada seção, com o redator e o revisor colaborando em cada uma
- Por fim, irá compilar tudo em um guia abrangente
Isso demonstra o poder dos flows para orquestrar processos complexos envolvendo múltiplos componentes, tanto de IA quanto não-IA.
Passo 9: Visualize Seu Flow
Uma das funcionalidades mais poderosas dos flows é a possibilidade de visualizar sua estrutura:
Isso irá criar um arquivo HTML que mostra a estrutura do seu flow, incluindo os relacionamentos entre etapas e o fluxo de dados. Essa visualização pode ser inestimável para entender e depurar flows complexos.
Passo 10: Revise o Resultado
Depois que o flow finalizar, você encontrará dois arquivos no diretório output
:
guide_outline.json
: Contém o roteiro estruturado do guiacomplete_guide.md
: O guia abrangente com todas as seções
Reserve um momento para revisar esses arquivos e apreciar o que você construiu – um sistema que combina entrada do usuário, interações diretas com IA e trabalho colaborativo de agents para produzir um output complexo e de alta qualidade.
A Arte do Possível: Além do Seu Primeiro Flow
O que você aprendeu neste guia é uma base para criar sistemas de IA muito mais sofisticados. Veja algumas formas de expandir este flow básico:
Aprimorando a Interação com o Usuário
Você pode criar flows mais interativos com:
- Interfaces web para entrada e saída de dados
- Atualizações em tempo real de progresso
- Loops de feedback e refinamento interativos
- Interações multi-stage com o usuário
Adicionando Mais Etapas de Processamento
Você pode expandir seu flow com etapas adicionais para:
- Pesquisa antes da criação do roteiro
- Geração de imagens para ilustrações
- Geração de snippets de código para guias técnicos
- Garantia de qualidade e checagem final de fatos
Criando Flows Mais Complexos
Você pode implementar padrões de flow mais sofisticados:
- Ramificações condicionais com base na preferência do usuário ou tipo de conteúdo
- Processamento paralelo de seções independentes
- Loops de refinamento iterativo com feedback
- Integração a APIs e serviços externos
Aplicando a Diferentes Domínios
Os mesmos padrões podem ser usados para criar flows de:
- Narrativas interativas: criação de histórias personalizadas com base na entrada do usuário
- Inteligência de negócios: processamento de dados, geração de insights e criação de relatórios
- Desenvolvimento de produtos: facilitação de ideação, design e planejamento
- Sistemas educacionais: criação de experiências de aprendizagem personalizadas
Principais Funcionalidades Demonstradas
Este flow de criação de guia demonstra diversos recursos poderosos do CrewAI:
- Interação com o usuário: O flow coleta input diretamente do usuário
- Chamadas diretas à LLM: Usa a classe LLM para interações eficientes e direcionadas com IA
- Dados estruturados com Pydantic: Usa Pydantic para garantir segurança de tipos
- Processamento sequencial com contexto: Escreve seções em ordem, fornecendo as anteriores como contexto
- Crews multiagentes: Utiliza agents especializados (redator e revisor) para criação de conteúdo
- Gerenciamento de estado: Mantém estado entre diferentes etapas do processo
- Arquitetura orientada a eventos: Usa o decorator
@listen
para responder a eventos
Entendendo a Estrutura do Flow
Vamos decompor os principais componentes dos flows para ajudá-lo a entender como construir o seu:
1. Chamadas Diretas à LLM
Flows permitem que você faça chamadas diretas a modelos de linguagem quando precisa de respostas simples e estruturadas:
Isso é mais eficiente do que usar um crew quando você precisa de um output específico e estruturado.
2. Arquitetura Orientada a Eventos
Flows usam decorators para estabelecer relações entre componentes:
Isso cria uma estrutura clara e declarativa para sua aplicação.
3. Gerenciamento de Estado
Flows mantêm o estado entre as etapas, facilitando o compartilhamento de dados:
Isso fornece uma maneira segura e tipada de rastrear e transformar dados ao longo do flow.
4. Integração com Crews
Flows podem integrar crews para tarefas colaborativas complexas:
Assim, você usa a ferramenta certa para cada parte da aplicação – chamadas diretas para tarefas simples e crews para colaboração avançada.
Próximos Passos
Agora que você construiu seu primeiro flow, pode:
- Experimentar estruturas e padrões mais complexos de flow
- Testar o uso do
@router()
para criar ramificações condicionais em seus flows - Explorar as funções
and_
eor_
para execuções paralelas e mais complexas - Conectar seu flow a APIs externas, bancos de dados ou interfaces de usuário
- Combinar múltiplos crews especializados em um único flow
Parabéns! Você construiu seu primeiro CrewAI Flow que combina código regular, chamadas diretas a LLM e processamento baseado em crews para criar um guia abrangente. Essas habilidades fundamentais permitem criar aplicações de IA cada vez mais sofisticadas, capazes de resolver problemas complexos de múltiplas etapas por meio de controle procedural e inteligência colaborativa.