Skip to main content

Azur Lane asset downloader and extractor

Project description

Azur Lane Asset Downloader and Extractor

This tool automatically downloads the newest assets directly from the game's CDN servers and allows extraction of Texture2D files as PNG images.

Upgrade Notice

From 2.x / no version number to 3.x+

When upgrading from versions 2.x or with no version number, the project has to be newly set up. To retain all current data the following folders can be copied to the new folder of the project:

  • config: Only user_config.yml is required, the rest can be deleted.
  • ClientAssets or directory set in asset-directory of the config: Contains all currently downloaded assets, version information und update logs used for extraction. Highly recommend to transfer to the new project folder.

Setup

Before installation, Python 3.11 or newer needs to be available on the system. It is recommended to set the project up using venv or a similar virtual environment manager. The project can be installed using pip:

pip install azlassets

Alternatively, to install the newest version from the repository (requires git on the system):

pip install git+https://github.com/nobbyfix/AzurLane-AssetDownloader.git

Usage

There are three scripts to manage the assets:

  • obb_apk_import: Importing assets from obb/apk/xapk files
  • downlader: Downloading assets from the game server
  • extractor: Extract PNGs from the assets

These can be executed using py -m <scriptname> on Windows or python3 -m <scriptname> on Linux/macOS (will be shortened to py[thon3] going forward, use the appropriate version for your system). Detailed usage will be explained in the following sections.

1. Import files from xapk/apk/obb

While this is not necessary, this step is recommended if you want all game assets available and not spam the game update server with errors of missing files on the first download.

The obb_apk_import.py supports all game clients (EN, JP, CN, KR, TW) and multiple forms of importing the assets. The recommended and easiest way is by downloading the .xapk from one of many Google Play Store app distributors (like APKMirror or APKPure). You can find them by searching for the package name, which are as follows:

  • EN: com.YoStarEN.AzurLane
  • JP: com.YoStarJP.AzurLane
  • KR: kr.txwy.and.blhx
  • TW: com.hkmanjuu.azurlane.gp

Alternatively if you already have the game installed, for example on emulators, you can copy the obb file onto your system and use it instead of the xapk. On Android it can be found in the folder /storage/emulated/0/Android/obb/[PACKAGE_NAME]/.

Since the CN client is not distributed through the Google Play Store, there is no xapk/obb file for it, but you can find the android download link on the website which will download an apk file (not xapk like the others). Alternatively, the APK is installed in the folder /data/app/com.bilibili.azurlane-1/ on android (Note: Root access is required to access this folder).

You can then execute the script by passing it the filepath to the xapk/apk/obb:

py[thon3] -m obb_apk_import [FILEPATH]

2. Settings

The config/user_config.yml file provides a few settings to filter which files will be downloaded (and later also extracted). The options download-folder-listtype and extract-folder-listtype can be set to either "blacklist" or "whitelist". Depending on this it will filter by the top-level folder names (subfolders are not supported) or top-level filenames (files inside top-level folders or lower cannot be filtered) set in download-folder-list and extract-folder-list. This allows to cut down the download and extraction times by skipping unneeded assets.

3. Download new updates from the game

All assets normally distributed via the in-app downloader can be downloaded by simply executing:

py[thon3] -m downloader [CLIENT]

where CLIENT has to be either EN, CN, JP, KR or TW. You can check which files have been downloaded or deleted using the difflog files in ClientAssets/[CLIENT]/difflog.

4. Extract all new and changed files

The asset extraction script supports extraction of all newly downloaded files and single asset bundles. The newly downloaded assets can be extracted by executing:

py[thon3] -m extractor [CLIENT]

where CLIENT is again one of EN, CN, JP, KR or TW. The extracted images will then be saved in ClientExtract/[CLIENT]/ Since only Texture2D assets are exported, it's not desired to try to export from all assetbundles (See settings section).

A single assetbundle can be extracted by passing the filepath to the script:

py[thon3] -m extractor -f [FILEPATH]

5. Enjoy the files

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

azlassets-3.5.0.tar.gz (22.5 kB view details)

Uploaded Source

Built Distribution

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

azlassets-3.5.0-py3-none-any.whl (24.7 kB view details)

Uploaded Python 3

File details

Details for the file azlassets-3.5.0.tar.gz.

File metadata

  • Download URL: azlassets-3.5.0.tar.gz
  • Upload date:
  • Size: 22.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for azlassets-3.5.0.tar.gz
Algorithm Hash digest
SHA256 d2785ad6b00ff237d8c9df7132da920f1e2f55b59543285e9f8fc7fbfe28ba2e
MD5 c852bda3d14463dd02396f74b261d1ce
BLAKE2b-256 092c3112805edf5edaa8993db3b83c68d323f3004b3c044ab8c1621a9ec606a4

See more details on using hashes here.

Provenance

The following attestation bundles were made for azlassets-3.5.0.tar.gz:

Publisher: publish.yml on nobbyfix/AzurLane-AssetDownloader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file azlassets-3.5.0-py3-none-any.whl.

File metadata

  • Download URL: azlassets-3.5.0-py3-none-any.whl
  • Upload date:
  • Size: 24.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for azlassets-3.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a790da9499bc0db267ebd589bc6f0e769142975117351173cec4929b5a451052
MD5 62bfe8321bf0b3406b661c25ebc310c6
BLAKE2b-256 df22946813af50954340d939119421cfad09bfc9f2586cce810afd75de71ffc7

See more details on using hashes here.

Provenance

The following attestation bundles were made for azlassets-3.5.0-py3-none-any.whl:

Publisher: publish.yml on nobbyfix/AzurLane-AssetDownloader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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