Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soccermetrics/soccermetrics-client-py
Python client library for the Soccermetrics soccer analytics APIs.
https://github.com/soccermetrics/soccermetrics-client-py
Last synced: 3 months ago
JSON representation
Python client library for the Soccermetrics soccer analytics APIs.
- Host: GitHub
- URL: https://github.com/soccermetrics/soccermetrics-client-py
- Owner: soccermetrics
- License: mit
- Created: 2013-09-03T07:00:01.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2014-08-10T07:11:28.000Z (over 10 years ago)
- Last Synced: 2024-08-02T16:36:54.240Z (6 months ago)
- Language: Python
- Homepage:
- Size: 8.68 MB
- Stars: 72
- Watchers: 21
- Forks: 26
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-starts - soccermetrics/soccermetrics-client-py - Python client library for the Soccermetrics soccer analytics APIs. (others)
README
Soccermetrics API Python Client
===============================This is a Python module for using the Soccermetrics REST API.
# Build Status
[![Build Status](https://travis-ci.org/soccermetrics/soccermetrics-client-py.svg?branch=master)]
(https://travis-ci.org/soccermetrics/soccermetrics-client-py)# Installation
The Soccermetrics API Python client library depends on the
[Requests](http://docs.python-requests.org/en/latest/) and
[easydict](http://pypi.python.org/pypi/easydict/) libraries. You can install
the client library within a virtual environment on your computer, or install
it system-wide.Python 2.6+ is required.
It's not required, but [autoenv](https://github.com/kennethreitz/autoenv) is
very nice to have.## Virtual Environment Install
We recommend installing `soccermetrics-client-py` within a virtual environment
using `virtualenv`. That way you can run different versions of Python
installations and libraries without dealing with conflicting dependencies.We also recommend installing [virtualenvwrapper](http://virtualenvwrapper.readthedocs.org/en/latest/).
As it says on the label, it is a wrapper around `virtualenv` that manages the virtual
environments on your machine and allows you to customize pre- and post-activation
(and deactivation) behavior, such as setting environment variables or opening your text editor.Here is a link to [a nice tutorial on Virtualenv](http://sccr.mx/TXAL2F).
And [a tutorial on virtualenvwrapper](http://sccr.mx/1pZ5Xtx) as well.To install `virtualenv` on MacOS or Linux, create a folder and run one of these
two commands as `sudo`:$ sudo easy_install virtualenv
or
$ sudo pip install virtualenv
If you are on Windows, [this link](http://flask.pocoo.org/docs/installation/#windows-easy-install)
will show you how to install `pip` and `distribute`, which you will use to
install `virtualenv`.Download [the current zipped version of the source code]
(https://github.com/soccermetrics/soccermetrics-client-py/archive/master.zip)
from GitHub, unzip the folder and run:$ make install
## System-Wide Install
If you want to install `soccermetrics-client-py` system-wide -- not recommended
because of possible library conflicts -- download
[the current zipped version of the source code]
(https://github.com/soccermetrics/soccermetrics-client-py/archive/master.zip)
from GitHub, unzip the folder and run:$ make install
# Getting Started
To start using the Soccermetrics API, create a `SoccermetricsRestClient`.
## API Credentials
You'll need your Soccermetrics API credentials to use the `SoccermetricsRestClient`.
These get passed to the constructor directly or via environment variables.```python
from soccermetrics.rest import SoccermetricsRestClientappID = "f53baabb"
appKey = "demo1234567890demo1234567890"client = SoccermetricsRestClient(account=appID,api_key=appKey)
```If you call `SoccermetricsRestClient` without any parameters, the constructor
will look for `SOCCERMETRICS_APP_ID` and `SOCCERMETRICS_APP_KEY` variables
inside the current environment.We recommend that you keep your credentials in environment variables.
That way you won't have to worry about accidentally posting your credentials
in a public place.```python
from soccermetrics.rest import SoccermetricsRestClient
client = SoccermetricsRestClient()
```## Get Match Information
```python
from soccermetrics.rest import SoccermetricsRestClientappID = "f53baabb"
appKey = "demo1234567890demo1234567890"
client = SoccermetricsRestClient()# club teams
match = client.club.information.get(home_team_name="Everton",
away_team_name="Liverpool").data[0]
print match.matchDate, match.kickoffTimelineup_data = client.link.get(match.link.lineups, is_starting=True).all()
for datum in lineup_data:
print datum.playerName, datum.playerTeamName# national teams
natl_match = client.natl.information.get(
home_team_name="Brazil", away_team_name="Croatia",phase="Group").data[0]
lineup_data = client.link.get(natl_match.link.lineups, is_starting=True).all()
for datum in lineup_data:
print datum.playerName, datum.playerTeamName
```## Get Player Statistical Data
```python
from soccermetrics.rest import SoccermetricsRestClientappID = "f53baabb"
appKey = "demo1234567890demo1234567890"
client = SoccermetricsRestClient()player = client.players.get(full_name=u'Robin van Persie').data[0]
# goals at club level
goals = client.link.get(player.link.club.goals)
penalties = client.link.get(player.link.club.penalties,outcome_type="Goal")
# goals at national team level
natl_team_goals = client.link.get(player.link.natl.goals)
natl_team_pens = client.link.get(player.link.natl.penalties,outcome_type="Goal")
```## Get Advanced Analytics
```python
from soccermetrics.rest import SoccermetricsRestClient
client = SoccermetricsRestClient()match = client.club.information.get(home_team_name='Manchester United', away_team_name='Stoke City').data[0]
match_state_46 = client.link.get(match.link.analytics.match.state,time_mins=46)
match_state_75 = client.link.get(match.link.analytics.match.state,time_mins=75)
match_state_final = client.link.get(match.link.analytics.match.state)
match_segments = client.link.get(match.link.analytics.match.segment)
```# Learn More
* [Link to API documentation](http://soccermetrics.github.io/connect-api).
* [Link to full client documentation here](http://soccermetrics.github.io/soccermetrics-client-py).