Enterprise ready Python OData client
Project description
Python OData Client - pyodata
Python OData client which provides comfortable Python agnostic way for communication with OData services.
The goal of this Python module is to hide all OData protocol implementation details.
Requirements
Download and Installation
Install and update using pip:
pip install -U pyodata
Configuration
You can start building your OData projects straight away after installing the Python module without any additional configuration steps needed.
Limitations
There have been no limitations discovered yet.
Known Issues
There are no known issues at this time.
How to obtain support
We accept bug reports, feature requests, questions and comments via GitHub issues
Usage
The only thing you need to do is to import the pyodata Python module and provide an object implementing interface compatible with Session Object for the library Requests.
import requests
import pyodata
SERVICE_URL = 'http://services.odata.org/V2/Northwind/Northwind.svc/'
# Create instance of OData client
client = pyodata.Client(SERVICE_URL, requests.Session())
Find more sophisticated examples in The User Guide.
Contributing
Before contributing, please, make yourself familiar with git. You can try git online. Things would be easier for all of us if you do your changes on a branch. Use a single commit for every logical reviewable change, without unrelated modifications (that will help us if need to revert a particular commit). Please avoid adding commits fixing your previous commits, do amend or rebase instead.
Every commit must have either comprehensive commit message saying what is being changed and why or a link (an issue number on Github) to a bug report where this information is available. It is also useful to include notes about negative decisions - i.e. why you decided to not do particular things. Please bare in mind that other developers might not understand what the original problem was.
Full example
Here's an example workflow for a project PyOData
hosted on Github
Your username is yourname
and you're submitting a basic bugfix or feature.
- Hit 'fork' on Github, creating e.g.
yourname/PyOData
. git clone git@github.com:yourname/PyOData
git checkout -b foo_the_bars
to create new local branch named foo_the_bars- Hack, hack, hack
- Run
python -m pytest
ormake check
git status
git add
git commit -s -m "Foo the bars"
git push -u origin HEAD
to create foo_the_bars branch in your fork- Visit your fork at Github and click handy "Pull request" button.
- In the description field, write down issue number (if submitting code fixing an existing issue) or describe the issue + your fix (if submitting a wholly new bugfix).
- Hit 'submit'! And please be patient - the maintainers will get to you when they can.
License
Copyright (c) 2019 SAP SE or an SAP affiliate company. All rights reserved. This file is licensed under the Apache Software License, v. 2 except as noted otherwise in the LICENSE file
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pyodata-1.2.2.tar.gz
.
File metadata
- Download URL: pyodata-1.2.2.tar.gz
- Upload date:
- Size: 35.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.8.0 tqdm/4.31.1 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 12afed29253d710ac4301530f155405285c8fc3b36ecfab1a54e14f3f8d12063 |
|
MD5 | 88402460bf0fe1c7110b92c68e58e0ee |
|
BLAKE2b-256 | 29e73ca07a78faa8c43fe4256cf1a0d217d2bba4a68aecd7b02a2eab0d915d78 |
File details
Details for the file pyodata-1.2.2-py3-none-any.whl
.
File metadata
- Download URL: pyodata-1.2.2-py3-none-any.whl
- Upload date:
- Size: 34.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.8.0 tqdm/4.31.1 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c88167f2c93effa3eda60e46c56a8c33b62e2e299e04bfcfbe345f43ae35202c |
|
MD5 | cdc0df3dde473efceb0236af58066a17 |
|
BLAKE2b-256 | 7e2f1ddc84c30fd227c7490f845374cf7fed9df39ee00ce37c7cdb2aee41f5d6 |