Betting trading framework
Project description
flūmine
Betting trading framework with a focus on:
- simplicity
- modular
- pythonic
- rock-solid
- safe
Support for market, order and custom streaming data.
Tested on Python 3.8, 3.9, 3.10, 3.11 and 3.12.
installation
$ pip install flumine
flumine requires Python 3.8+
setup
Get started...
import betfairlightweight
from flumine import Flumine, clients
trading = betfairlightweight.APIClient("username")
client = clients.BetfairClient(trading)
framework = Flumine(
client=client,
)
Example strategy:
from flumine import BaseStrategy
from flumine.order.trade import Trade
from flumine.order.order import LimitOrder, OrderStatus
from flumine.markets.market import Market
from betfairlightweight.filters import streaming_market_filter
from betfairlightweight.resources import MarketBook
class ExampleStrategy(BaseStrategy):
def start(self) -> None:
print("starting strategy 'ExampleStrategy'")
def check_market_book(self, market: Market, market_book: MarketBook) -> bool:
# process_market_book only executed if this returns True
if market_book.status != "CLOSED":
return True
def process_market_book(self, market: Market, market_book: MarketBook) -> None:
# process marketBook object
for runner in market_book.runners:
if runner.status == "ACTIVE" and runner.last_price_traded < 1.5:
trade = Trade(
market_id=market_book.market_id,
selection_id=runner.selection_id,
handicap=runner.handicap,
strategy=self
)
order = trade.create_order(
side="LAY",
order_type=LimitOrder(price=1.01, size=2.00)
)
market.place_order(order)
def process_orders(self, market: Market, orders: list) -> None:
for order in orders:
if order.status == OrderStatus.EXECUTABLE:
if order.size_remaining == 2.00:
market.cancel_order(order, 0.02) # reduce size to 1.98
if order.order_type.persistence_type == "LAPSE":
market.update_order(order, "PERSIST")
if order.size_remaining > 0:
market.replace_order(order, 1.02) # move
strategy = ExampleStrategy(
market_filter=streaming_market_filter(
event_type_ids=["7"],
country_codes=["GB"],
market_types=["WIN"],
)
)
framework.add_strategy(strategy)
Run framework:
framework.run()
Features
- Streaming
- Multiple strategies
- Multiple clients
- Order execution
- Paper trading
- Simulation
- Event simulation (multi market)
- Middleware and background workers to enable Scores / RaceCard / InPlayService
Dependencies
flumine relies on these libraries:
betfairlightweight
- Betfair API supporttenacity
- Used for connection retrying (streaming)python-json-logger
- JSON loggingrequests
- HTTP supportsmart-open
- Efficient streaming of very large files from/to storages such as S3, including (de)compression
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
flumine-2.6.5.tar.gz
(3.3 MB
view details)
Built Distribution
flumine-2.6.5-py3-none-any.whl
(79.2 kB
view details)
File details
Details for the file flumine-2.6.5.tar.gz
.
File metadata
- Download URL: flumine-2.6.5.tar.gz
- Upload date:
- Size: 3.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 02a779afbd916e8fc646479eb14243680c122afb0cb4ad2975073ccd3b589149 |
|
MD5 | 29018b31204d706d0a7e13b19d97464f |
|
BLAKE2b-256 | 471da0490ad09d0eee862f9b52f83bf9158c3357a71802706cf0d64f5d77f220 |
File details
Details for the file flumine-2.6.5-py3-none-any.whl
.
File metadata
- Download URL: flumine-2.6.5-py3-none-any.whl
- Upload date:
- Size: 79.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fe91302766e737b66adc0707922d3af4ffdce2a0a2cd2f551127f17fa6786559 |
|
MD5 | 4e8d0af66a7111560ac0c838766191a5 |
|
BLAKE2b-256 | c3fb12f269051c0abb741fe0366ea189bf8ead3f60457a443a3ca300489431f1 |