Skip to main content

Async API wrapper for akasha.cv written in Python

Project description

akasha-py

Introduction

akasha-py is an async API wrapper for akasha.cv written in Python.
akasha.cv is a Genshin Impact leaderboard website.
Developing something for Hoyoverse games? You might be interested in other API wrappers written by me.

Note: I am not the developer of akasha.cv.

Important Notes

A couple things I want to address:

  • This wrapper is currently in-progress, some features may not work as expected, many features are also missing.
  • The developer of akasha.cv mentioned to me that they change their API very frequently (and without notice), so this wrapper may break at any time.
  • This wrapper was made because I wanted to integrate akasha into my Discord bot, but I eventually stopped working on it. Therefore, this wrapper is not my current priority, but I will fix issues if you submit them.

Installation

# poetry
poetry add akasha-py

# pip
pip install akasha-py

Usage

Interact with the API using the akasha.AkashaAPI class.
You can find all available methods that AkashaAPI provides in the client.py file.
A quick example is provided below:

import asyncio

import akasha


async def main() -> None:
    uid = 901211014
    async with akasha.AkashaAPI(akasha.Language.CHINESE_SIMPLIFIED) as api:
        # await api.refresh_user(uid)

        characters = await api.get_calculations_for_user(uid)
        for character in characters:
            calc = character.calculations[0]

            print(f"Character: {character.name}")
            print(f"Weapon: {calc.weapon.name}")
            print(f"Top {calc.top_percent:.2f}% ({calc.ranking}/{calc.out_of})")
            print(f"Damage: {round(calc.result)}")
            print()

            print("Leaderboard top 3:")
            async for board in api.get_leaderboards(calc.id, max_page=1, page_size=3):
                print(
                    f"{board.rank}. {board.owner.nickname} | Damage: {round(board.calculation.result)}"
                )
            print(f"Leadboard URL: https://akasha.cv/leaderboards/{calc.id}")

            print("=" * 50)


asyncio.run(main())

Questions, Issues, Feedback, Contributions

Whether you want to make any bug reports, feature requests, or contribute to the wrapper, simply open an issue or pull request in this repository.
If GitHub is not your type, you can find me on Discord, my username is @seria_ati.

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

akasha_py-0.2.12.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

akasha_py-0.2.12-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file akasha_py-0.2.12.tar.gz.

File metadata

  • Download URL: akasha_py-0.2.12.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.8

File hashes

Hashes for akasha_py-0.2.12.tar.gz
Algorithm Hash digest
SHA256 6faf4fca6fbddc1c16804704536991e101649157b59144b143c88743294a7251
MD5 3ee81f6ec7d8dec2f7a8db34472fa98a
BLAKE2b-256 f6f0448ee05a89f109c4a6560b5be72ef579b6ff4f0e8b6d0b963f9936327c45

See more details on using hashes here.

File details

Details for the file akasha_py-0.2.12-py3-none-any.whl.

File metadata

File hashes

Hashes for akasha_py-0.2.12-py3-none-any.whl
Algorithm Hash digest
SHA256 666293d810041b97c631fba1db2e6e35e3ab1967d6fe5826f12ee50c6c3e6c6f
MD5 66553da0e14b6293fe50b3321e2ea795
BLAKE2b-256 65049f29e228505d80c7ecb798e9fd23cfc3a8e54423be88645f6636506650d2

See more details on using hashes here.

Supported by

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