TwitchIO Examples
Quick update with code that I'm using to respond to message with twitchio (opposed to !commands). The original code is further below, but somehtings not working with it anymore. (This is as of September, 2021)
So, this is what I'm doing now.
#!/usr/bin/env python3
=
=
=
=
# Only respond if you can confirm the bot didn't send the mssage
await
=
Something about the way this sends messages to chat is weird. Regular messages look like this when printed out by the script.
2021-09-05 23:23:37.041000 - theidofalan - this is a thing I wrote
Messages from the bot look like :
1970-01-19 21:01:24.217000 - [Unknown Author] - bleep bloop. I saw the sign
Here are the old notes for reference. Some may work, but others won't.
## OLD NOTES - Some Of These Might Not Work
_ I updated twitchio and keep getting [TODO: Code shorthand span ] errors like :
AttributeError: 'Bot' object has no attribute '_ws'
Here are three ways to use TwitchIO to respond to commands, respond to messages, and to work without interaction.
(Note : I'm using [TODO: Code shorthand span ] in these examples, but I use [TODO: Code shorthand span ] in my scripts. It uses the system credential store and is well worth a look if you're not familiar with it.)
### Respond To Commands
#!/usr/bin/env python3
=
=
=
=
await
=
### Respond To Messages
This one responds to any message sent to the channel. Make sure to filter out message from the bot like I do here otherwise it'll create a loop talking to itself. That'll send messages as fast as it can which gets the bot timed out for an hour. (Ask me how I know...)
#!/usr/bin/env python3
=
=
=
=
=
await
=
### Non - Interactive
This one posts a message as soon as the bot is connected and ready. No interaction required.
It also starts a loop that sets a message every 2 seconds (which is about as fast as Twitch allows). Note that the sleep is done with ` asyncio.sleep ` . Using [TODO: Code shorthand span ] would block the script and it would never get out of ` event _ ready ` . With the [TODO: Code shorthand span ] call other events can be processed (e.g. [TODO: Code shorthand span ] will run for incoming messages.)
#!/usr/bin/env python3
=
=
=
=
=
await
await
await
=