拆分带有媒体内容的消息和不带电报Program机器人的消息

Split message with media content and without Telegram pyrogram Bot(拆分带有媒体内容的消息和不带电报Program机器人的消息)
本文介绍了拆分带有媒体内容的消息和不带电报Program机器人的消息的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个脚本来复制和拆分消息从源聊天到目标聊天,使用的是PYROGRAM PYTHON库。脚本应该在分开的消息上拆分大于300个符号的消息,如果消息中没有媒体内容,他这样做没有任何问题。带有媒体内容(照片、音频、视频)的消息将被忽略,并且再也不会被复制到目标聊天中。

有没有人知道我怎么才能让脚本复制并拆分每条消息,无论有没有内容,超过300个符号?

编码:

#!/usr/bin/env python3
from pyrogram import Client
from pyrogram import filters

# ~~~~~~ CONFIG ~~~~~~~~ #
ACCOUNT = "@account"
PHONE_NR = 'number'

API_ID = APIID
API_HASH = "APIHASH"

app = Client( ACCOUNT, phone_number=PHONE_NR, api_id=API_ID, api_hash=API_HASH )

### CHAT ID

# Variables
SOURCE_CHAT_TEST = chat_id
TARGET_CHAT_TEST = chat_id
# ~~~~~~~~~~~~~~~~~~~~~~ #

# Commands
@app.on_message(filters.text & filters.chat(SOURCE_CHAT_TEST))
def copy_to_channel(client, message):
    if len(message.text) >= 300:
        for i in range(0, len(message.text), 300):
            client.send_message(
                chat_id=TARGET_CHAT_TEST,
                text=message.text[i:i+300])
    else:
        message.copy(  chat_id=TARGET_CHAT_TEST  )

app.run()

推荐答案

尝试此操作以检查是否存在文本,而不考虑消息类型:

@app.on_message(filters.chat(SOURCE_CHAT_TEST))
def copy_to_channel(client, message):
    if message.text:
        if len(message.text) >= 300:
            for i in range(0, len(message.text), 300):
                client.send_message(
                    chat_id=TARGET_CHAT_TEST,
                    text=message.text[i:i+300])
        else:
            message.copy(  chat_id=TARGET_CHAT_TEST  )
    else:
        pass

这篇关于拆分带有媒体内容的消息和不带电报Program机器人的消息的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)