Skip to main content

A Python library to automate video uploads to YouTube.

Project description

🚀 upload-socials

Streamline your content workflow by automating video uploads to YouTube with this Python library. Now supports automated monetization settings!


⚠️ Prerequisites

This is a GUI automation library and requires a specific setup to function:

  1. Screen Resolution: Your screen resolution should ideally be 1920x1080. The browser window should be maximized during the process.
  2. Reference Images: GUI automation works by finding images on the screen. You must provide your own folders of reference images (e.g., screenshots of the 'Upload', 'Next', and 'Publish' buttons).
  3. Platform Language: The YouTube Studio website must be set to English.

This library is best suited for developers comfortable with tuning GUI automation scripts.

Installation

pip install upload-socials

Setup: Reference Images

You must create a directory (e.g., assets/youtube) containing screenshots of the YouTube Studio interface. The script looks for .png files with specific names.

Basic Upload Images:

  • create.png, uploadvids.png, select.png
  • filename.png (The file input field in Windows Explorer)
  • title.png, tell.png (Description box)
  • thumbnail.png
  • showmore.png, tags.png
  • next.png, publish.png
  • processing.png (The "SD/HD processing" checkmark at the end)

Monetization Images (Required if monetization=True):

  • monetizeselect.png (The monetization tab/dropdown)
  • monetizeon.png (Radio button to turn On)
  • monetizedone.png (Done button inside dropdown)
  • monetizeactive.png
  • monetizenone.png (The "None of the above" checkbox for ad suitability)
  • monetizesubmit.png (Submit rating button)
  • monetizepublic.png (Public visibility radio button)
  • publish2.png (Secondary publish button if layout differs)

Quick Start

from upload_socials import upload_youtube

# 1. Define the path to your screenshots folder
YT_IMAGE_PATH = r"C:\\my_automation_images\\youtube"

# 2. Define Video details
video_file = r"C:\\path\\to\\my_awesome_video.mp4"
video_title = "My First Automated Upload!"
video_desc = "This was uploaded using the upload-socials Python library."
thumb_file = r"C:\\path\\to\\my_thumbnail.png"
video_tags = "python,automation,coding"

# 3. Call the function
upload_youtube(
    filepath=video_file,
    title=video_title,
    image_path=YT_IMAGE_PATH,
    description=video_desc,
    thumbnail=thumb_file,
    tags=video_tags,
    monetization=True  # Set to True to enable ads and submit rating
)

API Reference

upload_youtube(...)

Automates the upload process to YouTube Studio.

Parameter Type Default Description
filepath str Required Absolute path to the video file.
title str Required The title of the YouTube video.
image_path str .../uploadyt Path to the folder containing your .png reference screenshots.
description str None The text for the video description.
channelurl str studio.youtube.com The starting URL.
thumbnail str None Absolute path to a thumbnail image.
tags str None Comma-separated string of tags.
monetization bool False If True, performs steps to enable monetization, select "None of the above" for suitability, and submit rating.

Tips for Success

  • Wait Times: The script uses optimiseWait to look for images. If your internet is slow, ensure your screenshots are accurate so the script doesn't time out.
  • Mouse Control: Do not touch the mouse or keyboard while the script is running.
  • Smart Paste: This library uses a smart pasting method to handle emojis and special characters in titles and descriptions automatically.

License

This project is licensed under the MIT License.

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

upload_socials-1.2.0.tar.gz (75.0 kB view details)

Uploaded Source

Built Distribution

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

upload_socials-1.2.0-py3-none-any.whl (79.2 kB view details)

Uploaded Python 3

File details

Details for the file upload_socials-1.2.0.tar.gz.

File metadata

  • Download URL: upload_socials-1.2.0.tar.gz
  • Upload date:
  • Size: 75.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.6

File hashes

Hashes for upload_socials-1.2.0.tar.gz
Algorithm Hash digest
SHA256 16160b31935eebbde8c6292f94415545f10f468a61f47c5fb1f93941bf4cc31c
MD5 44c705d08475cc5d628952a44407be48
BLAKE2b-256 07088cb89c12dd63788a22cab5bf14d65390bb47d97a809e6302908d8370047c

See more details on using hashes here.

File details

Details for the file upload_socials-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: upload_socials-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 79.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.6

File hashes

Hashes for upload_socials-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 940d9f9b0497af835a1ff61aa8f54cc7df82a5ecf7a69aa0546b1c54c1553b2e
MD5 6afe83039a0d9366332f34a565c3c753
BLAKE2b-256 52ad0844dcd5244b0c29ada08c4ef2a4aa195c4bf026a08ab43962572cf7214f

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