The following is a simple end-to-end example for using the GraphRAG system, using the install from pypi option.

It shows how to use the system to index some text, and then use the indexed data to answer questions about the documents.

**Install GraphRAG**

```
pip install graphrag
```

**Running the Indexer**
We need to set up a data project and some initial configuration. First let's get a sample dataset ready:


```
mkdir -p ./ragtest/input
```

I have `corpus.txt` inside the input file:

Set Up Your Workspace Variables

To initialize your workspace, first run the graphrag init command. Since we have already configured a directory named `./ragtest` in the previous step, run the following command:


```
graphrag init --root ./ragtest
```

This will create two files: `.env` and `settings.yaml` in the `./ragtest` directory.

`.env` contains the environment variables required to run the GraphRAG pipeline. If you inspect the file, you'll see a single environment variable defined, `GRAPHRAG_API_KEY=<API_KEY>`. Replace `<API_KEY>` with your own OpenAI.
`settings.yaml` contains the settings for the pipeline. You can modify this file to change the settings for the pipeline.

**Using OpenAI**

If running in OpenAI mode, you only need to update the value of `GRAPHRAG_API_KEY` in the `.env` file with your OpenAI API key.

Running the Indexing pipeline
Finally we'll run the pipeline!

```
graphrag index --root ./ragtest
```

pipeline executing from the CLI

This process will take some time to run. This depends on the size of your input data, what model you're using, and the text chunk size being used (these can be configured in your `settings.yaml` file). Once the pipeline is complete, you should see a new folder called `./ragtest/output` with a series of parquet files.

Using the Query Engine
Now let's ask some questions using this dataset.

Here is an example using Global search to ask a high-level question:


```
graphrag query \
--root ./ragtest \
--method global \
--query "What are the top themes in this story?"
```

Here is an example using Local search to ask a more specific question about a particular character:

```
graphrag query \
--root ./ragtest \
--method local \
--query "Who is Scrooge and what are his main relationships?"
```

Please refer to Query Engine docs for detailed information about how to leverage our Local and Global search mechanisms for extracting meaningful insights from data after the Indexer has wrapped up execution.