A python wrapper for the PUBG Developer API
PUBG Developer API Official Documentation
To install the wrapper, simply use pip
pip install pubg-python
or pipenv
pipenv install pubg-python
The PUBG API shards data by platform and region, and therefore requires a shard to be specified in the URL for most requests.
from pubg_python import PUBG, Shard
api = PUBG('<api-key>', Shard.PC_NA)
A list of shards can be found here and the wrapper constants here
- Players
player = api.players().get('account.3654e255b77b409e87b10dcb086ab00d')
for match in player.matches:
match_data = api.matches().get(match.id)
players = api.players().filter(player_names=['Name1', 'Name2'])
for player in players:
player_id = player.id
players = api.players().filter(player_ids=['account.3654e255b77b409e87b10dcb086ab00d'])
for player in players:
player_name = player.name
- Matches
match = api.matches().get('276f5bcb-a831-4e8c-a610-d2073692069e')
Still unavailable in the API
match_ids = [
'276f5bcb-a831-4e8c-a610-d2073692069e',
'fasf9082-21de-dkle-13ke-qlamd13nab3a',
]
matches = api.matches().filter(match_ids=match_ids)
for match in matches:
print(match)
- Telemetry events
- Event objects
match = api.matches().get('276f5bcb-a831-4e8c-a610-d2073692069e')
asset = match.assets[0]
telemetry = api.telemetry(asset.url)
print(len(telemetry.events))
>> 16871
Sometimes you're interested in a set of very specific events, so there is a helper function to filter those for you:
match = api.matches().get('276f5bcb-a831-4e8c-a610-d2073692069e')
asset = match.assets[0]
telemetry = api.telemetry(asset.url)
player_kill_events = telemetry.events_from_type('LogPlayerKill')
player_position_events = telemetry.events_from_type('LogPlayerPosition')
An example of how you can manipulate the data: The domain is all specified here
players = api.players().filter(player_names=['epickitten'])
player = players[0]
player.matches
>> [<Match bd6aae34-be05-4094-981c-083285c7e861>, <Match 276f5bcb-a831-4e8c-a610-d2073692069e>, ..]
match = api.matches().get(player.matches[0].id)
match.game_mode
>> 'solo'
match.duration
>> 1899
match.rosters
>> [<Roster d542eaee-cd02-4f4e-ad7f-ed5ea71a17cf>, <Roster e9f0962a-ebd4-4d86-b134-95783b713800>, ..]
roster = match.rosters[0]
roster.participants
>> [<Participant 7cc76d1b-a80e-4997-8eb8-d4b3c1ed4f44>]
participant = roster.participans[0]
participant.name
>> 'urdaddyYO'
participant.damage_dealt
>> 291.08
participant.kills
>> 2
participant.ride_distance
>> 3204.53467
participant.walk_distance
>> 2262.81714
participant.time_survived
>> 1367
participant.player_id
>> account.edb9910f1e9c4f3b9addb87d9329b57c
player = api.players().get(participant.player_id)
player
>> account.edb9910f1e9c4f3b9addb87d9329b57c
player.matches
>> [<Match b3dcd7e8-2270-4fdd-8389-af77acf2d6c2>, <Match 2ebb1a9c-ab5e-4264-971f-df77a00918a9>, ..]
Offsetting 5 matches and limitting by 10
matches = api.matches().limit(10).offset(5)
sort
defaults to ascending, you can use ascending=False
for a descending sort
matches = api.matches().limit(10).sort('createdAt')
matches = api.matches().limit(10).sort('createdAt', ascending=False)
A list of filters can be found here
squad_matches = api.matches().filter(game_mode='squad')
solo_matches = api.matches().filter(game_mode='solo')
after_2018_before_2019 = api.matches().filter(
created_at_start='2018-01-01T00:00:00Z',
created_at_end='2019-01-01T00:00:00Z'
)
You don't need to use the Enum
s if you don't want to:
squad_matches = api.matches().filter(game_mode='squad')
solo_matches = api.matches().filter(game_mode='solo')
And you can also chain filters:
squad_queryset = api.matches().filter(game_mode='squad')
squad_after_2018 = squad_queryset.filter(created_at_start='2018-01-01T00:00:00Z')
Use next()
for the next page and prev()
for the previous one:
matches = api.matches()
next_matches = matches.next()
previous_matches = matches.prev()
Be aware of rate limits:
matches = api.matches()
while matches:
for match in matches:
print(match)
matches = matches.next()