Skip to main content

Send tweets with images from the command line

Project description

tweet-images

PyPI Changelog Tests License

Send tweets with images from the command line

Installation

Install this tool using pip:

pip install tweet-images

Example

This tool is used by the @covidsewage bot on Twitter, see simonw/covidsewage-bot and Building a Covid sewage Twitter bot.

Usage

You'll need a consumer key, consumer secret, access token key and access token secret for a Twitter account that you wish to tweet from. See How to get credentials for a new Twitter bot for tips on obtaining these.

You can pass those as the --consumer-key, --consumer-secret, --access-token-key, --access-token-secret options to the command, or you can set them as environment variables like this:

export TWITTER_CONSUMER_KEY="..."
export TWITTER_CONSUMER_SECRET="..."
export TWITTER_ACCESS_TOKEN_KEY="..."
export TWITTER_ACCESS_TOKEN_SECRET=".."

You can then send a tweet like this:

tweet-images "This is my tweet"

Or attach between one and four images to that tweet by passing their file paths:

tweet-images "Three pictures attached" one.jpg two.jpg three.jpg

You can pass --alt "alt text" one or more times to attach alt text to your images:

tweet-images "Three pictures attached" one.jpg two.jpg \
  --alt "Alt text for one" --alt "Alt text for two"

Using this with GitHub Actions

Here's an example fragment from a GitHub Actions workflow that uses this tool. The repository has four repository secrets configured with the necessary credentials, and a previous step has already installed the tweet-images Python package:

    - name: Tweet the new image
      env:
        TWITTER_CONSUMER_KEY: ${{ secrets.TWITTER_CONSUMER_KEY }}
        TWITTER_CONSUMER_SECRET: ${{ secrets.TWITTER_CONSUMER_SECRET }}
        TWITTER_ACCESS_TOKEN_KEY: ${{ secrets.TWITTER_ACCESS_TOKEN_KEY }}
        TWITTER_ACCESS_TOKEN_SECRET: ${{ secrets.TWITTER_ACCESS_TOKEN_SECRET }}
      run: |-
        tweet-images "Latest Covid sewage charts for the SF Bay Area" \
          /tmp/covid.png --alt "Screenshot of the charts"

Development

To contribute to this tool, first checkout the code. Then create a new virtual environment:

cd tweet-images
python -m venv venv
source venv/bin/activate

Now install the dependencies and test dependencies:

pip install -e '.[test]'

To run the tests:

pytest

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

tweet-images-0.1.2.tar.gz (7.5 kB view details)

Uploaded Source

Built Distribution

tweet_images-0.1.2-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file tweet-images-0.1.2.tar.gz.

File metadata

  • Download URL: tweet-images-0.1.2.tar.gz
  • Upload date:
  • Size: 7.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.4

File hashes

Hashes for tweet-images-0.1.2.tar.gz
Algorithm Hash digest
SHA256 6c7526ee73bca2f4c13bfa17b1a2bffc9e7d562715041a1f8c07357853e4e8d5
MD5 ac5def057b6c7a47ef3525220e5ade9d
BLAKE2b-256 ff711f09cbec1011eb10c1415f99196e1860c777478605955ec01f404ad98b07

See more details on using hashes here.

File details

Details for the file tweet_images-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for tweet_images-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e2711115059014e0fdd746109546bddf1d33bfd85b057c6add6274bac2067bb8
MD5 1b773c890f6b0370b9e65a5a67ad54f1
BLAKE2b-256 1dd24d992adfeda41b85c7abb6adcca776dc628f547b6b3bb76e6c1341e0bdd4

See more details on using hashes here.

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