Skip to main content

Python bindings to CrunchBase

Project description

Documentation Status Travis-CI Build Status coveralls
PyPI Package latest release PyPI Package monthly downloads PyPI Wheel Supported versions Supported imlementations

Python bindings to CrunchBase

Starting from v0.3.0, pycrunchbase has support for CrunchBase API version 3, but things are still flaky, so any kind of bug reports is greatly appreciated, for detail see notes below.

Note: I currently do not need to use this library, so it’s feature-complete for me. Bug reports are welcome, and pull requests for features are still accepted.

Examples

Initialize the API using your API Key, will throw ValueError if missing

cb = CrunchBase(API_KEY)

Look up an organization by name

github = cb.organization('github')

The response contains snippets of data regarding relationships that the organization has, an example is the funding_rounds

funding_rounds_summary = github.funding_rounds

All relationships are paged, and only 8 is returned initially to get more data do this, it handles paging for you and returns a False-y value if there are no more pages

more_funding_rounds = cb.more(funding_rounds_summary)

Data in relations are just summaries, and you probably want more details For example funding_rounds returns 5 values: type, name, path created_at, updated_at.

If you actually want to know who invested, you have to get to make more API calls.

First get the uuid of the round

round_uuid = funding_rounds_summary[0].uuid

Then use the CrunchBase API to make that call

round = cb.funding_round(round_uuid)

Again, investments is a relationship on a FundingRound, so we can get the first item in that relationship

an_investor = round.investments[0]  # a Investment

And printing that gives us the name of the investor, and the amount invested in USD

print(str(an_investor))  # prints: Investment: [Organization: Name]

Installation

pip install pycrunchbase

Documentation

https://readthedocs.org/projects/pycrunchbase/

Development

To run the all tests run:

tox

Contributions are always welcome! Visit pycrunchbase’s Homepage <https://github.com/ngzhian/pycrunchbase/>

Use GitHub issues to report a bug or send feedback.

The best way to send feedback is to file an issue at https://github.com/ngzhian/pycrunchbase/issues.

Contributors

Thanks to these contributors:

Goals

  1. Support all (or almost all) of CrunchBase’s API functionalities

  2. Speedy updates when CrunchBase’s API changes

  3. ‘Pythonic’ bindings, user doesn’t feel like we’re requesting URLs

Notes on CrunchBase version 3 changes

In version 3, CrunchBase changed the names of some endpoints, e.g person -> people, and they have gone with the plural form of all entities. pycrunchbase does not adhere strictly to that. For example, there is still a person method, but a people method is also provided so that it remains backwards compatible and also supports methods that matches the name of the entity.

License

MIT

Changelog

0.3.6 (2015-10-21) * Alias ‘PressReference’ to news * Fix checking for the type of a PageItem, use lowercase compare * Update test data, those were out of sync with what CrunchBase no returns. Specifically the test data for Fund and Relationship (Organization.past_team)

0.3.5 (2015-09-28) * Fixed handling null rleationships that api returns * Update setup.py release alias

0.3.4 (2015-09-27) * Fixed instructions in usage.rst (#20) * Support nested relationships FundingRound -> Investments -> Organization * Update README

0.3.3 (2015-08-29)

  • Added stock_exchange as a known property of Organization, ref #19 <https://github.com/ngzhian/pycrunchbase/issues/19>

0.3.2 (2015-07-25)

  • New resource type StockExchange (fixes #18)

  • Better __str__ for IPO

0.3.1 (2015-05-25)

  • Bug fix when relationship data returned from crunchbase is [null]. Thanks @karlalopez

0.3.0 (2015-05-01)

  • Updated to support version 3 of CrunchBase API

  • Fix endpoint urls, e.g. ‘funding-round’ -> ‘funding-rounds’

  • Internal cleanups, Page now subclass Relationship

0.2.7 (2015-04-23)

  • Fixed: #9 sub_organization and websites relationship of Organization

0.2.6 (2015-04-13)

  • Fixed: #8 printing PageItem leads to unbounded recursion (@dustinfarris)

0.2.5 (2015-04-04)

  • Added: Locations - get a list of active locations from CrunchBase

  • Added: LocationPageItem - each location in the Page of Locations

  • Added: Categories - get a list of active categories from CrunchBase

  • Added: CategoryPageItem - each location in the Page of Categories

0.2.4 (2015-04-03)

  • Added: IPO - you can now use a uuid to grab IPO data

0.2.3 (2015-03-01)

  • Fix: Travis builds and tests

0.2.2 (2015-02-25)

  • Fix: Unicode output (using UTF-8 encoding)

0.2.1 (2015-02-21)

  • Fix __version__

0.2.0 (2015-02-15)

  • The API is now considered relatively stabled. Updated the classifier to reflect so

  • Change to how CrunchBase.more reacts to a Relationship, we no longer optimize when the Relationship has all items, just call first_page_url

0.1.9 (2015-02-15)

  • Add series to the FundingRound node.

0.1.8 (2015-02-15)

  • Update __str__ for nodes and relationships

0.1.7 (2015-02-15)

  • Relationship is now a subclass of Page, although this strictly isn’t true. The benefit is that this allows us to reuse a lot of logic. Relationship can be thought of as Page 0, which is a summary of potentially multiple pages of PageItem. The only time we get a relationship is when we query for a particular Node, e.g. organiation, and we grab the relationships returned by the API. After this, to get more details we call Crunchbase.more, and this returns us a Page.

  • Added __repr__ methods to all the Node, Relationship, PageItem. Previously we only defined __str__, but these didn’t show up in places like the REPL. This fixes that. We try to make it obvious what object it is based on what is printed, but also don’t want to be too verbose.

0.1.6 (2015-02-15)

  • InvestorInvestmentPageItem now has the possibility of being either a investor, or a invested_in relationship

  • Propogates any exception when making the actual HTTP call to CrunchBase

0.1.5 (2015-02-13)

  • Add a cb_url attribute for all PageItem, this url is a CrunchBase page (not the API) that holds more information for a particular PageItem Allows you to make calls like:

    company.funding_rounds[0].cb_url

    to get the url of the page for the first funding round of company.

  • A new page item, InvestorInvestmentPageItem, that is useful for FundingRound info:

    round = cb.funding_round('round_uuid')
    an_investor = round.investments[0]  # a InvestorInvestmentPageItem
    print(str(an_investor))  # prints: Investor Name $100000
  • Add simplified Contribution guidelines in README

0.1.4 (2015-02-13)

  • Relationship retrieval is 0-based now, 1-based just doesn’t fit well with array

  • Better __str__ for Node and Relationship

  • Relationship.get(i) if i is too large or small will return a NonePageItem singleton

0.1.3 (2015-02-12)

  • Fix Relationship: wasn’t using the right build method of PageItem

  • Add test to checkk for the above

  • remove unused reference to CrunchBase in Relationship

0.1.2 (2015-02-12)

  • PageItem and it’s subclasses to represent an item within a relationship of a Node

  • Cleanup of where utility methods live (parse_date)

  • More tests as always, overall 98.21% coverage

0.1.0 (2015-02-21)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pycrunchbase-0.3.6.tar.gz (304.3 kB view hashes)

Uploaded Source

Built Distribution

pycrunchbase-0.3.6.linux-x86_64.tar.gz (28.5 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page