Package Exports
- google-search-ts
- google-search-ts/dist/googleSearch.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (google-search-ts) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
google-search-ts
A TypeScript library for performing Google searches with support for proxy, pagination, and customization.
Installation
npm install google-search-tsUsage
import { GoogleSearch, SearchOptions } from 'google-search-ts';
// Basic search
const results = await GoogleSearch.search('nodejs typescript');
// Search with options
const options: SearchOptions = {
    numResults: 20,        // Number of results to return
    lang: 'en',           // Language for search results
    safe: 'active',       // SafeSearch setting ('active' or 'off')
    region: 'US',         // Region for search results
    start: 0,             // Starting position for pagination
    unique: true,         // Remove duplicate URLs
    proxy: 'http://proxy.example.com:8080',  // Optional proxy
    timeout: 5000         // Request timeout in milliseconds
};
const resultsWithOptions = await GoogleSearch.search('nodejs typescript', options);
// Each result contains:
// {
//     url: string;        // The URL of the search result
//     title: string;      // The title of the search result
//     description: string; // The description/snippet of the search result
// }Examples
Basic Search
import { GoogleSearch } from 'google-search-ts';
async function basicSearch() {
    try {
        const results = await GoogleSearch.search('nodejs typescript');
        console.log(`Found ${results.length} results`);
        
        // Print the first result
        console.log('First result:', {
            title: results[0].title,
            url: results[0].url,
            description: results[0].description
        });
    } catch (error) {
        console.error('Search failed:', error.message);
    }
}Pagination
import { GoogleSearch } from 'google-search-ts';
async function paginatedSearch() {
    const query = 'typescript tutorials';
    const resultsPerPage = 10;
    
    try {
        // Get first page
        const page1 = await GoogleSearch.search(query, {
            numResults: resultsPerPage,
            start: 0
        });
        
        // Get second page
        const page2 = await GoogleSearch.search(query, {
            numResults: resultsPerPage,
            start: resultsPerPage
        });
        
        const allResults = [...page1, ...page2];
        console.log(`Total results: ${allResults.length}`);
    } catch (error) {
        console.error('Paginated search failed:', error.message);
    }
}Language and Region-Specific Search
import { GoogleSearch } from 'google-search-ts';
async function localizedSearch() {
    try {
        // Search in French, restricted to France
        const frenchResults = await GoogleSearch.search('dรฉveloppeur web', {
            lang: 'fr',
            region: 'FR',
            numResults: 10
        });
        
        // Search in German, restricted to Germany
        const germanResults = await GoogleSearch.search('webentwickler', {
            lang: 'de',
            region: 'DE',
            numResults: 10
        });
        
        console.log('French results:', frenchResults.length);
        console.log('German results:', germanResults.length);
    } catch (error) {
        console.error('Localized search failed:', error.message);
    }
}Using a Proxy
import { GoogleSearch } from 'google-search-ts';
async function searchWithProxy() {
    try {
        const results = await GoogleSearch.search('programming jobs', {
            proxy: 'http://your-proxy-server:8080',
            timeout: 10000,  // Increased timeout for proxy
            numResults: 15
        });
        
        console.log(`Found ${results.length} job listings`);
    } catch (error) {
        console.error('Proxy search failed:', error.message);
    }
}Error Handling
import { GoogleSearch } from 'google-search-ts';
async function robustSearch() {
    try {
        const results = await GoogleSearch.search('typescript examples', {
            numResults: 20,
            unique: true  // Remove duplicate URLs
        });
        
        if (results.length === 0) {
            console.log('No results found');
            return;
        }
        
        // Process results
        results.forEach((result, index) => {
            console.log(`${index + 1}. ${result.title}`);
            console.log(`   URL: ${result.url}`);
            console.log(`   Description: ${result.description}\n`);
        });
        
    } catch (error) {
        if (error.message.includes('timeout')) {
            console.error('Search timed out. Try increasing the timeout value.');
        } else if (error.message.includes('proxy')) {
            console.error('Proxy error. Check your proxy configuration.');
        } else {
            console.error('Search failed:', error.message);
        }
    }
}Features
- ๐ Perform Google searches programmatically
- ๐ Support for different languages and regions
- ๐ SafeSearch support
- ๐ Pagination support
- ๐ Proxy support
- ๐ฏ Customizable number of results
- ๐ซ Duplicate URL filtering
- โฑ๏ธ Configurable timeout
- ๐ TypeScript type definitions included
Options
| Option | Type | Default | Description | 
|---|---|---|---|
| numResults | number | 10 | Number of results to return | 
| lang | string | 'en' | Language for search results | 
| proxy | string | undefined | Proxy URL (e.g., 'http://proxy.example.com:8080') | 
| timeout | number | 5000 | Request timeout in milliseconds | 
| safe | 'active' | 'off' | 'active' | SafeSearch setting | 
| region | string | undefined | Region for search results | 
| start | number | 0 | Starting position for pagination | 
| unique | boolean | false | Remove duplicate URLs from results | 
License
MIT
Contributing
Contributions are welcome! Please feel free to submit a Pull Request to the GitHub repository.