Skip to main content

Python API for Photoshop.

Project description

logo

python version PyPI version Documentation Status Downloads Status Downloads License pypi format Chat on Discird Maintenance

All Contributors

Python API for Photoshop.

The example above was created with Photoshop Python API. Check it out at photoshop-python-api.readthedocs.io/examples.

Has been tested and used Photoshop version:

Photoshop Version Supported
2020 :white_check_mark:
cc2019 :white_check_mark:
cc2018 :white_check_mark:
cc2017 :white_check_mark:

Installing

You can install via pip.

pip install photoshop_python_api

or through clone from Github.

git clone https://github.com/loonghao/photoshop_python_api.git

Install package.

python setup.py install

Since it uses COM (Component Object Model) connect Photoshop, it can be used in any DCC software with a python interpreter.

Hello World

import photoshop.api as ps
app = ps.Application()
doc = app.documents.add()
new_doc = doc.artLayers.add()
text_color = ps.SolidColor()
text_color.rgb.green = 255
new_text_layer = new_doc
new_text_layer.kind = ps.LayerKind.TextLayer
new_text_layer.textItem.contents = 'Hello, World!'
new_text_layer.textItem.position = [160, 167]
new_text_layer.textItem.size = 40
new_text_layer.textItem.color = text_color
options = ps.JPEGSaveOptions(quality=5)
# # save to jpg
jpg = 'd:/hello_world.jpg'
doc.saveAs(jpg, options, asCopy=True)
app.doJavaScript(f'alert("save to jpg: {jpg}")')

demo

Photoshop Session

Use it as context.

from photoshop import Session


with Session(action="new_document") as ps:
    doc = ps.active_document
    text_color = ps.SolidColor()
    text_color.rgb.green = 255
    new_text_layer = doc.artLayers.add()
    new_text_layer.kind = ps.LayerKind.TextLayer
    new_text_layer.textItem.contents = 'Hello, World!'
    new_text_layer.textItem.position = [160, 167]
    new_text_layer.textItem.size = 40
    new_text_layer.textItem.color = text_color
    options = ps.JPEGSaveOptions(quality=5)
    jpg = 'd:/hello_world.jpg'
    doc.saveAs(jpg, options, asCopy=True)
    ps.app.doJavaScript(f'alert("save to jpg: {jpg}")')

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Hal

💻

voodraizer

🐛

brunosly

🐛

tubi

🐛

wjxiehaixin

🐛

罗马钟

🐛

clement

🐛

krevlinmen

🐛

This project follows the all-contributors specification. Contributions of any kind are welcome!

how to get Photoshop program ID

Get-ChildItem "HKLM:\SOFTWARE\Classes" | 
  ?{ ($_.PSChildName -match "^[a-z]+\.[a-z]+(\.\d+)?$") -and ($_.GetSubKeyNames() -contains "CLSID") } | 
  ?{ $_.PSChildName -match "Photoshop.Application" } | ft PSChildName

get_program_id

How to get a list of COM objects from the registry

Useful links

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

photoshop-python-api-0.16.0.tar.gz (48.4 kB view details)

Uploaded Source

Built Distribution

photoshop_python_api-0.16.0-py3-none-any.whl (62.2 kB view details)

Uploaded Python 3

File details

Details for the file photoshop-python-api-0.16.0.tar.gz.

File metadata

  • Download URL: photoshop-python-api-0.16.0.tar.gz
  • Upload date:
  • Size: 48.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.9.5 Linux/5.4.0-1047-azure

File hashes

Hashes for photoshop-python-api-0.16.0.tar.gz
Algorithm Hash digest
SHA256 9bd42cb5662cdbc69fc5ec89c54b72004a75e91a0e9202e984748ac08e66d7a1
MD5 401d23f5199f97ffa9186cd7a5cf8657
BLAKE2b-256 47843833006827467ed3ea43b3c36f295a2af7b247bb63018a4c6db08326565d

See more details on using hashes here.

Provenance

File details

Details for the file photoshop_python_api-0.16.0-py3-none-any.whl.

File metadata

File hashes

Hashes for photoshop_python_api-0.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2f7c5843da62963330113f0a502298569eb54a0e7cdbcabed363864ca945a094
MD5 aa73478cc05639f3c7430ff9594d1534
BLAKE2b-256 4f74ff96a87b3ae9fc38085a270dd5c92ed5fbafc1cc10e37dc3c40da88a69c8

See more details on using hashes here.

Provenance

Supported by

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