# Como reutilizar o código de outras pessoas nos seus projetos

Aumente sua eficiência em codificação e seus conhecimentos integrando o código existente aos seus projetos.

Uma das melhores coisas sobre open source software é a capacidade de reutilizar o código de outras pessoas. A reutilização de código ajuda você a economizar tempo, descobrir novas funcionalidades e aprender outros estilos de programação. Há duas maneiras principais de reutilizar o código:

* **Copiar e colar um snippet de código diretamente no projeto.** Se você ainda estiver se familiarizando com a codificação, essa será a maneira mais rápida de começar a reutilizar um código.
* **Importar uma biblioteca para o projeto.** Embora essa abordagem exija algum tempo para ser aprendida, ela é, no final, mais simples e eficiente. Também é uma habilidade fundamental para o desenvolvimento de software.

Neste artigo, aprenderemos sobre ambos os aspectos ao trabalhar por meio de um exemplo: reutilizando o código Python que calcula o fatorial de um número.

## Como usar snippets de código de outras pessoas no seu projeto

Ao aprender a codificação pela primeira vez, você pode começar com a reutilização copiando e colando snippets de código de outras pessoas no seu projeto. É uma ótima forma de economizar tempo, mas há algumas etapas importantes que você sempre deve realizar antes de copiar o código de outros desenvolvedores.

### 1. Como encontrar e entender um snippet de código

Primeiro, você precisa encontrar e entender o snippet de código que deseja reutilizar. Para este exemplo, vamos escolher o repositório [`new2code/python-factorial`](https://github.com/new2code/python-factorial).

Primeiro, **abra**[`factorial_finder.py`](https://github.com/new2code/python-factorial/blob/main/factorial_finder.py), que implementa a calculadora usando um loop:

```python
# Initialize the factorial result to 1
factorial = 1

# Initialize the input number to 6
number = 6

# Loop from 1 to number (inclusive) and multiply factorial by each number
for i in range(1, number + 1):
    factorial *= i

print(f"The factorial of {number} is {factorial}")
```

Em seguida, na barra de menus na parte superior do arquivo, clique <svg version="1.1" width="16" height="16" viewBox="0 0 16 16" class="octicon octicon-copilot" aria-label="Ask Copilot about this file" role="img"><path d="M7.998 15.035c-4.562 0-7.873-2.914-7.998-3.749V9.338c.085-.628.677-1.686 1.588-2.065.013-.07.024-.143.036-.218.029-.183.06-.384.126-.612-.201-.508-.254-1.084-.254-1.656 0-.87.128-1.769.693-2.484.579-.733 1.494-1.124 2.724-1.261 1.206-.134 2.262.034 2.944.765.05.053.096.108.139.165.044-.057.094-.112.143-.165.682-.731 1.738-.899 2.944-.765 1.23.137 2.145.528 2.724 1.261.566.715.693 1.614.693 2.484 0 .572-.053 1.148-.254 1.656.066.228.098.429.126.612.012.076.024.148.037.218.924.385 1.522 1.471 1.591 2.095v1.872c0 .766-3.351 3.795-8.002 3.795Zm0-1.485c2.28 0 4.584-1.11 5.002-1.433V7.862l-.023-.116c-.49.21-1.075.291-1.727.291-1.146 0-2.059-.327-2.71-.991A3.222 3.222 0 0 1 8 6.303a3.24 3.24 0 0 1-.544.743c-.65.664-1.563.991-2.71.991-.652 0-1.236-.081-1.727-.291l-.023.116v4.255c.419.323 2.722 1.433 5.002 1.433ZM6.762 2.83c-.193-.206-.637-.413-1.682-.297-1.019.113-1.479.404-1.713.7-.247.312-.369.789-.369 1.554 0 .793.129 1.171.308 1.371.162.181.519.379 1.442.379.853 0 1.339-.235 1.638-.54.315-.322.527-.827.617-1.553.117-.935-.037-1.395-.241-1.614Zm4.155-.297c-1.044-.116-1.488.091-1.681.297-.204.219-.359.679-.242 1.614.091.726.303 1.231.618 1.553.299.305.784.54 1.638.54.922 0 1.28-.198 1.442-.379.179-.2.308-.578.308-1.371 0-.765-.123-1.242-.37-1.554-.233-.296-.693-.587-1.713-.7Z"></path><path d="M6.25 9.037a.75.75 0 0 1 .75.75v1.501a.75.75 0 0 1-1.5 0V9.787a.75.75 0 0 1 .75-.75Zm4.25.75v1.501a.75.75 0 0 1-1.5 0V9.787a.75.75 0 0 1 1.5 0Z"></path></svg> para iniciar uma conversa com Copilot.

![Captura de tela do botão do Copilot, contornado em laranja-escuro, na parte superior da exibição do arquivo.](/assets/images/help/copilot/factorial-finder-copilot-button.png)

Na janela de chat, pergunte Copilot:

```text copy
Explain this program.
```

### 2. Noções básicas sobre licenciamento de projeto

Para reutilizar o código encontrado, você precisa entender como funciona o licenciamento dele. As licenças determinam como você pode usar o código em um projeto, incluindo sua capacidade de copiar, modificar e distribuir esse código.

Para identificar a licença de [new2code/python-factorial](https://github.com/new2code/python-factorial), localize a seção “Sobre” na página principal do repositório. Nela, você verá que o repositório está licenciado sob a licença MIT. Para ler a licença, clique na <svg version="1.1" width="16" height="16" viewBox="0 0 16 16" class="octicon octicon-law" aria-label="law" role="img"><path d="M8.75.75V2h.985c.304 0 .603.08.867.231l1.29.736c.038.022.08.033.124.033h2.234a.75.75 0 0 1 0 1.5h-.427l2.111 4.692a.75.75 0 0 1-.154.838l-.53-.53.529.531-.001.002-.002.002-.006.006-.006.005-.01.01-.045.04c-.21.176-.441.327-.686.45C14.556 10.78 13.88 11 13 11a4.498 4.498 0 0 1-2.023-.454 3.544 3.544 0 0 1-.686-.45l-.045-.04-.016-.015-.006-.006-.004-.004v-.001a.75.75 0 0 1-.154-.838L12.178 4.5h-.162c-.305 0-.604-.079-.868-.231l-1.29-.736a.245.245 0 0 0-.124-.033H8.75V13h2.5a.75.75 0 0 1 0 1.5h-6.5a.75.75 0 0 1 0-1.5h2.5V3.5h-.984a.245.245 0 0 0-.124.033l-1.289.737c-.265.15-.564.23-.869.23h-.162l2.112 4.692a.75.75 0 0 1-.154.838l-.53-.53.529.531-.001.002-.002.002-.006.006-.016.015-.045.04c-.21.176-.441.327-.686.45C4.556 10.78 3.88 11 3 11a4.498 4.498 0 0 1-2.023-.454 3.544 3.544 0 0 1-.686-.45l-.045-.04-.016-.015-.006-.006-.004-.004v-.001a.75.75 0 0 1-.154-.838L2.178 4.5H1.75a.75.75 0 0 1 0-1.5h2.234a.249.249 0 0 0 .125-.033l1.288-.737c.265-.15.564-.23.869-.23h.984V.75a.75.75 0 0 1 1.5 0Zm2.945 8.477c.285.135.718.273 1.305.273s1.02-.138 1.305-.273L13 6.327Zm-10 0c.285.135.718.273 1.305.273s1.02-.138 1.305-.273L3 6.327Z"></path></svg>**licença do MIT**.

![Captura de tela da página principal do repositório new2code/python-factorial. Na barra lateral direita, "MIT license" está destacada em laranja escuro.](/assets/images/help/repository/license-info-python-factorial.png)

Queremos copiar todo o arquivo `factorial_finder.py`, portanto, a licença MIT indica que devemos incluir uma cópia da licença em nosso projeto. Na parte superior do arquivo Python, cole a licença como um comentário.

> \[!TIP] Saiba o que é permitido por outras licenças comuns com a ferramenta [Choose a license](https://choosealicense.com/licenses/).

### 3. Como usar e modificar snippets de código

Agora está tudo pronto para você colar o snippet de código no projeto. Embora às vezes você possa usar snippets de código no estado em que se encontram, muitas vezes o ideal será **modificá-los** para o caso de uso específico. Vamos praticar isso agora.

Digamos que queremos calcular rapidamente os fatoriais de 5, 7, 9 e 10. Em vez de copiar e colar todo o programa para cada número, podemos mover a calculadora para uma **função** que usa um número como argumento.

Use [Bate-papo do Copilot](https://github.com/copilot) para sugerir e explicar uma implementação. Cole o código atual na janela de chat, seguido por esta solicitação:

```text copy
Wrap the Python code above in a function.
```

Copilot gerará um código semelhante a este:

```python copy
def calculate_factorial(number):
    # Initialize the factorial result to 1
    factorial = 1

    # Loop from 1 to number (inclusive) and multiply factorial by each number
    for i in range(1, number + 1):
        factorial *= i

    return factorial
```

Com nossa nova função, podemos facilmente encontrar os fatores de nossos números adicionando o seguinte código ao nosso projeto e, em seguida, executando o programa Python:

```python copy
print(calculate_factorial(5))
print(calculate_factorial(7))
print(calculate_factorial(9))
print(calculate_factorial(10))
```

Parabéns! Você encontrou, entendeu e modificou com sucesso um exemplo de snippet de código.

## Como usar um código de bibliotecas no seu projeto

Agora vamos aprender a usar bibliotecas, que é uma **prática padrão** para desenvolvedores. As bibliotecas são essencialmente coleções de códigos escritas por outros desenvolvedores para executar tarefas específicas. Você pode importar bibliotecas para seu projeto para usar o código pré-escrito, economizando tempo e esforço.

Nesta seção, continuaremos trabalhando com o exemplo da calculadora fatorial Python da seção anterior. Para referência, este é o código atual:

```python copy
def calculate_factorial(number):
    # Initialize the factorial result to 1
    factorial = 1

    # Loop from 1 to number (inclusive) and multiply factorial by each number
    for i in range(1, number + 1):
        factorial *= i

    return factorial

print(calculate_factorial(5))
print(calculate_factorial(7))
print(calculate_factorial(9))
print(calculate_factorial(10))
```

### 1. Como encontrar uma biblioteca

Depois de saber a funcionalidade que você deseja adicionar ao projeto, pesquise uma biblioteca com o código relevante.
Bate-papo do Copilot é uma maneira fácil de procurar bibliotecas, pois você pode usar a linguagem natural para descrever exatamente o que está procurando.

Encontrar um fatorial é uma função bastante comum e é bem provável que alguém tenha incluído essa função em uma biblioteca existente. Abra [Bate-papo do Copilot](https://github.com/copilot)e pergunte:

```text copy
Is there a Python library with a function for calculating a factorial?
```

Copilot nos informará que uma função fatorial está incluída no [`math`](https://docs.python.org/3/library/math.html) módulo da biblioteca padrão do Python.

### 2. Como priorizar a segurança no seu projeto

Ao adicionar uma biblioteca ou um módulo ao seu projeto, você cria o que é chamado de **dependência**. As dependências são pacotes de código pré-escritos dos quais o projeto depende para funcionar corretamente. Se elas não forem escritas com atenção ou não receberem uma manutenção adequada, poderão introduzir vulnerabilidades de segurança no seu trabalho.

A boa notícia é que há algumas etapas que você pode realizar para proteger melhor seu projeto. Vamos praticá-las agora.

#### Como usar bibliotecas populares

As bibliotecas populares costumam ser mais seguras porque são mantidas e usadas ativamente por muitos desenvolvedores. Um bom indicador de popularidade é o número de **estrelas** que um repositório tem. Se você não conseguir encontrar o repositório GitHub para uma dependência, poderá pedir ajuda a Copilot.

Abra [Bate-papo do Copilot](https://github.com/copilot)e pergunte:

```text copy
Find the GitHub repository containing the code for the math module in Python.
```

Copilot informará que o `math` módulo está definido em [`python/cpython`](https://github.com/python/cpython), que tem mais de 64.000 estrelas.

#### Habilitando Dependabot alerts para seu projeto

Quando habilitado, Dependabot alerts é gerado automaticamente quando Dependabot detecta um problema de segurança em suas dependências, ajudando você a corrigir rapidamente as vulnerabilidades.
Dependabot está disponível **gratuitamente** em todos os repositórios de software GitHub livre.

Ative Dependabot alerts para o seu repositório agora. Clique na aba **<svg version="1.1" width="16" height="16" viewBox="0 0 16 16" class="octicon octicon-shield" aria-label="shield" role="img"><path d="M7.467.133a1.748 1.748 0 0 1 1.066 0l5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667Zm.61 1.429a.25.25 0 0 0-.153 0l-5.25 1.68a.25.25 0 0 0-.174.238V7c0 1.358.275 2.666 1.057 3.86.784 1.194 2.121 2.34 4.366 3.297a.196.196 0 0 0 .154 0c2.245-.956 3.582-2.104 4.366-3.298C13.225 9.666 13.5 8.36 13.5 7V3.48a.251.251 0 0 0-.174-.237l-5.25-1.68ZM8.75 4.75v3a.75.75 0 0 1-1.5 0v-3a.75.75 0 0 1 1.5 0ZM9 10.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path></svg> Security and quality** do repositório do seu projeto GitHub. Clique ao lado de Dependabot alerts, em **Habilitar Dependabot alerts**. Você pode acessar Dependabot alerts pela guia **Dependabot** da barra lateral.

### 3. Como implementar o código de uma biblioteca

Agora está tudo pronto para você importar a biblioteca para seu projeto e, em seguida, usar o conteúdo dela no código. Você pode ler a documentação da biblioteca para saber como fazer isso por conta própria ou pode pedir Copilot para sugerir e explicar uma implementação para você.

Abra [Bate-papo do Copilot](https://github.com/copilot)e pergunte:

```text copy
How do I use the factorial function of the math module in my Python project?
```

Copilot em seguida, sugerirá uma versão do seguinte código:

```python copy
import math

# Calculate the factorial of a number
number = 5
result = math.factorial(number)

print(f"The factorial of {number} is {result}")
```

Depois de substituir o código existente no projeto pela implementação acima, você terá utilizado com sucesso o código de uma biblioteca no seu projeto de exemplo!

## Compartilhando seu trabalho

Com este tutorial, você aprendeu a reutilizar com segurança o código de outras pessoas em seu trabalho. Para comemorar, compartilhe como você reaproveitou o código e se baseou no projeto de exemplo em nossa [discussão na comunidade](https://github.com/orgs/community/discussions/153140).

## Leitura adicional

* [Localizando e entendendo código de exemplo](/pt/get-started/learning-to-code/finding-and-understanding-example-code)