Skill

Load GCS Files and Buckets

GCSReader loads files and directories from Google Cloud Storage buckets into LlamaIndex, supporting single files, prefix filters, and custom extractors.

Works with google cloud storage

91
Spark score
out of 100
Updated 3 months ago
Version 1.0.0
Models

Add to Favorites

Why it matters

Effortlessly ingest data from Google Cloud Storage into your AI applications. This asset can load individual files or entire buckets, providing a robust bridge for your data pipelines.

Outcomes

What it gets done

01

Load single files from GCS

02

Load entire GCS buckets with prefix filtering

03

List and retrieve information about GCS resources

04

Support for various GCS authentication methods

Install

Add it to your toolbox

Run in your project directory:

curl -fsSL https://spark.entire.vc/get/li-reader-readers-gcs | bash

Capabilities

What this skill does

Extract

Pulls structured data fields from unstructured text.

RAG index

Chunks, embeds, and indexes documents for semantic retrieval.

Audit access

Reviews permissions and logs to flag unauthorized activity.

Overview

GCS File or Directory Loader

What it does

A LlamaIndex data loader that parses files stored on Google Cloud Storage, supporting single files or entire buckets with optional prefix filtering.

How it connects

Use this when you need to load documents from GCS buckets into LlamaIndex, whether parsing individual files, processing entire buckets, or filtering by prefix with custom file extractors.

Source README

GCS File or Directory Loader

This loader parses any file stored on Google Cloud Storage (GCS), or the entire Bucket (with an optional prefix filter) if no particular file is specified. It now supports more advanced operations through the implementation of ResourcesReaderMixin and FileSystemReaderMixin.

Features

  • Parse single files or entire buckets from GCS
  • List resources in GCS buckets
  • Retrieve detailed information about GCS objects
  • Load specific resources from GCS
  • Read file content directly
  • Supports various authentication methods
  • Comprehensive logging for easier debugging
  • Robust error handling for improved reliability

Authentication

When initializing GCSReader, you may pass in your GCP Service Account Key in several ways:

  1. As a file path (service_account_key_path)
  2. As a JSON string (service_account_key_json)
  3. As a dictionary (service_account_key)

If no credentials are provided, the loader will attempt to use default credentials.

Usage

To use this loader, you need to pass in the name of your GCS Bucket. You can then either parse a single file by passing its key, or parse multiple files using a prefix.

from llama_index import GCSReader
import logging

### Set up logging (optional, but recommended)
logging.basicConfig(level=logging.INFO)

### Initialize the reader
reader = GCSReader(
    bucket="scrabble-dictionary",
    key="dictionary.txt",  # Optional: specify a single file
    # prefix="subdirectory/",  # Optional: specify a prefix to filter files
    service_account_key_json="[SERVICE_ACCOUNT_KEY_JSON]",
)

### Load data
documents = reader.load_data()

### List resources in the bucket
resources = reader.list_resources()

### Get information about a specific resource
resource_info = reader.get_resource_info("dictionary.txt")

### Load a specific resource
specific_doc = reader.load_resource("dictionary.txt")

### Read file content directly
file_content = reader.read_file_content("dictionary.txt")

print(f"Loaded {len(documents)} documents")
print(f"Found {len(resources)} resources")
print(f"Resource info: {resource_info}")
print(f"Specific document: {specific_doc}")
print(f"File content length: {len(file_content)} bytes")

Note: If the file is nested in a subdirectory, the key should contain that, e.g., subdirectory/input.txt.

Advanced Usage

All files are parsed with SimpleDirectoryReader. You may specify a custom file_extractor, relying on any of the loaders in the LlamaIndex library (or your own)!

from llama_index import GCSReader, SimpleMongoReader

reader = GCSReader(
    bucket="my-bucket",
    file_extractor={
        ".mongo": SimpleMongoReader(),
        # Add more custom extractors as needed
    },
)

Error Handling

The GCSReader now includes comprehensive error handling. You can catch exceptions to handle specific error cases:

from google.auth.exceptions import DefaultCredentialsError

try:
    reader = GCSReader(bucket="your-bucket-name")
    documents = reader.load_data()
except DefaultCredentialsError:
    print("Authentication failed. Please check your credentials.")
except Exception as e:
    print(f"An error occurred: {str(e)}")

Logging

To get insights into the GCSReader's operations, configure logging in your application:

import logging

logging.basicConfig(level=logging.INFO)

This loader is designed to be used as a way to load data into LlamaIndex. For more advanced usage, including custom file extractors, metadata extraction, and working with specific file types, please refer to the LlamaIndex documentation.

Discussion

Questions & comments · 0

Sign In Sign in to leave a comment.