Skip to main content

Library for working with Valve Pak files

Project description

Latest version released on PyPi MIT License Build status of master branch

VPK is Valve’s file format for storing game assets. Pythonic access to VPK files and their contents together with a cli tool.

Tested and works on python2.6, python2.7, python3.2+, pypy and pypy3.


You can grab the latest release from or via pip

pip install vpk

Quick start

The VPK instance is iterable in the standard ways and produces paths to files

import vpk

pak1 ="/d/Steam/steamapps/common/dota 2 beta/dota/pak01_dir.vpk")

for filepath in pak1:
    print filepath

Reading a specifc file is done by passing the file path to get_file() method, which returns a VPKFile instance, which acts as a regular file instance. Writting is not possible.

pakfile = pak1.get_file("scripts/emoticons.txt")
pakfile = pak1["scripts/emoticons.txt"]
    // An ID of zero is invalid

        "image_name" "wink.png"
        "ms_per_frame" "100"

Saving a file is just as easy."./emoticons.txt")

The module supports creating basic VPKs. Multi archive paks are not yet supported.

newpak ="./some/directory")"file.vpk")

pak = newpak.save_and_open("file.vpk")

CLI tool

A command line utility is also included

usage: vpk [-h] [--version] [-l] [-la] [-x OUT_LOCATION] [-nd] [-t] [-c DIR]
           [-p] [-f WILDCARD | -re REGEX | -name WILDCARD]

Manage Valve Pak files

optional arguments:
  -h, --help            show this help message and exit
  --version             show program's version number and exit

  file                  Input VPK file
  -l, --list            List file paths
  -la                   List file paths, crc, size
                        Exctract files to directory
  -nd, --no-directories
                        Don't create directries during extraction
  -t, --test            Verify contents
  -c DIR, --create DIR  Create VPK file from directory
  -p, --pipe            Write file contents to stdout

  -f WILDCARD, --filter WILDCARD
                        Wildcard filter for file paths
  -re REGEX, --regex REGEX
                        Regular expression filter for file paths
  -name WILDCARD        Filename wildcard filter

Looking to decompile Valve custom asset formats?

Check out

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for vpk, version 1.3.2
Filename, size File type Python version Upload date Hashes
Filename, size vpk-1.3.2-py2.py3-none-any.whl (10.4 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size vpk-1.3.2.tar.gz (10.4 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page