pypi i gsearch


๐Ÿ” Google Search unofficial API for Python with no external dependencies

by Avi Aryan

1.6.0 (see all)
pypi i gsearch

Python Google Search API

Version Build Status

Unofficial Google Search API for Python.

It uses web scraping in the background and is compatible with both Python 2 and 3.

Why this project?

No such library exists which works out of the box i.e. without requiring any external dependencies. I did this so that I can use it on my Alfred workflow. But this turned out to be pretty generic, feel free to use it for your own work.


  • Free unrestricted API, requires no key or credit card
  • Unicode support
  • Works for all Python versions (2 & 3)


pip install gsearch

NOTE: By using this library, you agree to its Terms and Conditions.


> from gsearch.googlesearch import search

> results = search('Full Stack Developer')  # returns 10 or less results
[ ('Name', 'Link'),
    ('Name', 'Link'),
    ... ]

> results = search('Avi Aryan', num_results=20)  # returns 20 or less results

You can also use it as a CLI tool.

$ gsearch "ๅ›ใฎๅ"

1. ๆ˜ ็”ปใ€Žๅ›ใฎๅใฏใ€‚ใ€ๅ…ฌๅผใ‚ตใ‚คใƒˆ
2. ๅ›ใฎๅใฏใ€‚ - Wikipedia
3. ๅ›ใฎๅใฏใ€‚ : ไฝœๅ“ๆƒ…ๅ ฑ - ๆ˜ ็”ป.com
4. ๅ›ใฎๅใฏใ€‚ - ไฝœๅ“ - Yahoo!ๆ˜ ็”ป
5. ใ€Žๅ›ใฎๅใฏใ€‚ใ€็ฑณใƒกใƒ‡ใ‚ฃใ‚ขโ€œ็Ÿ›็›พโ€ใ‚’ๆŒ‡ๆ‘˜ใ—ใคใคใ‚‚ใ€Œไธ€ๆตใ€ใจ็ตถ่ณ› | dmenuๆ˜ ็”ป
6. ใ€Œๅ›ใฎๅใฏใ€‚ใ€ไบˆๅ‘Š - YouTube
7. ๅ›ใฎๅใฏใฎใƒใ‚ฟใƒใƒฌ - ใ€ๅ›ใฎๅใฏใ€‚ใ€‘ใ‚ใ‚‰ใ™ใ˜ใ‚„ใƒใ‚ฟใƒใƒฌใ‹ใ‚‰่ˆžๅฐใฎ่–ๅœฐ ...
8. ใ€Žๅ›ใฎๅใฏใ€‚ใ€ใฎๆทฑใ™ใŽใ‚‹ใ€Œ15ใ€ใฎ็›ฒ็‚น | ใ‚ทใƒใƒžใ‚บ by ๆพ็ซน
9. ๅ›ใฎๅใฏ: DVD - ใ‚ขใƒžใ‚พใƒณ


>>> from gsearch.googlesearch import search
>>> search('Python')
[('Welcome to', ''), ('Python (programming language) - Wikipedia', ''), ('Python tutorial - TutorialsPoint', ''), ('Learn Python (Programming Tutorial for Beginners) - Programiz', ''), ('Learn Python | Codecademy', ''), ('Learn Python | Codecademy', ''), ('Introduction ยท A Byte of Python', ''), ('Solve Introduction Questions | Python | HackerRank', '')]
>>> search('Google Search API', num_results=15)
[('Custom Search JSON/Atom API | Custom Search | Google Developers', ''), ('Custom Search | Google Developers', ''), ('Using REST to Invoke the API | Custom Search | Google Developers', ''), ('Custom Search Engine - Google', ''), ('What are the alternatives now that the Google web search API has ...', ''), ('Is there an API for Google search results? - Quora', ''), ('Fetch Google Search Results with the Site Search API -', ''), ('Google Custom Search API | ProgrammableWeb', ''), ('Google Search API Alternative |', ''), ('FAROO - Free Search API', ''), ("Google's Ajax Search API | Search Engine Watch", ''), ('Search | GitHub Developer Guide', ''), ('Using the Google SOAP Search API - SEO Chat', '')]


Overusing this library might lead to your IP being blocked by Google Search servers. Searches through Chrome or another browser might still work but this library will stop working. I recommend keeping a 15 seconds gap after each usage of this library. In most cases, much lower gaps or even continuous use of the library will still work but still this is something to be kept in mind. If you see a 'rate limit' or a 503 error, it's best to stop using the library and try back after some time (~1 minute).


google by Mario Vilas - A library which does almost the same thing except that it uses external dependencies. This library also has some additional optimizations to reduce the chances of hitting rate limit.