當前位置: 首頁>>代碼示例>>Python>>正文


Python utils.get_input_location方法代碼示例

本文整理匯總了Python中telethon.utils.get_input_location方法的典型用法代碼示例。如果您正苦於以下問題:Python utils.get_input_location方法的具體用法?Python utils.get_input_location怎麽用?Python utils.get_input_location使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在telethon.utils的用法示例。


在下文中一共展示了utils.get_input_location方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: download_file

# 需要導入模塊: from telethon import utils [as 別名]
# 或者: from telethon.utils import get_input_location [as 別名]
def download_file(
    self: TelegramClient, location: TypeLocation,
    out: BinaryIO, progress_callback: callable = None
) -> BinaryIO:
    size = location.size
    dc_id, location = utils.get_input_location(location)
    # We lock the transfers because telegram has connection count limits
    downloader = ParallelTransferrer(self, dc_id)
    downloaded = downloader.download(location, size)
    async for x in downloaded:
        out.write(x)
        if progress_callback:
            r = progress_callback(out.tell(), size)
            if inspect.isawaitable(r):
                await r

    return out 
開發者ID:TG-UserBot,項目名稱:TG-UserBot,代碼行數:19,代碼來源:FastTelethon.py

示例2: download_file

# 需要導入模塊: from telethon import utils [as 別名]
# 或者: from telethon.utils import get_input_location [as 別名]
def download_file(self: TelegramClient,
                        location: TypeLocation,
                        out: BinaryIO,
                        progress_callback: callable = None) -> BinaryIO:
    size = location.size
    dc_id, location = utils.get_input_location(location)
    # We lock the transfers because telegram has connection count limits
    downloader = ParallelTransferrer(self, dc_id)
    downloaded = downloader.download(location, size)
    async for x in downloaded:
        out.write(x)
        if progress_callback:
            r = progress_callback(out.tell(), size)
            if inspect.isawaitable(r):
                await r

    return out 
開發者ID:mkaraniya,項目名稱:BotHub,代碼行數:19,代碼來源:FastTelethon.py

示例3: parallel_transfer_to_matrix

# 需要導入模塊: from telethon import utils [as 別名]
# 或者: from telethon.utils import get_input_location [as 別名]
def parallel_transfer_to_matrix(client: MautrixTelegramClient, intent: IntentAPI,
                                      loc_id: str, location: TypeLocation, filename: str,
                                      encrypt: bool, parallel_id: int) -> DBTelegramFile:
    size = location.size
    mime_type = location.mime_type
    dc_id, location = utils.get_input_location(location)
    # We lock the transfers because telegram has connection count limits
    async with parallel_transfer_locks[parallel_id]:
        downloader = ParallelTransferrer(client, dc_id)
        data = downloader.download(location, size)
        decryption_info = None
        up_mime_type = mime_type
        if encrypt and async_encrypt_attachment:
            async def encrypted(stream):
                nonlocal decryption_info
                async for chunk in async_encrypt_attachment(stream):
                    if isinstance(chunk, dict):
                        decryption_info = EncryptedFile.deserialize(chunk)
                    else:
                        yield chunk

            data = encrypted(data)
            up_mime_type = "application/octet-stream"
        content_uri = await intent.upload_media(data, mime_type=up_mime_type, filename=filename,
                                                size=size if not encrypt else None)
        if decryption_info:
            decryption_info.url = content_uri
    return DBTelegramFile(id=loc_id, mxc=content_uri, mime_type=mime_type,
                          was_converted=False, timestamp=int(time.time()), size=size,
                          width=None, height=None, decryption_info=decryption_info) 
開發者ID:tulir,項目名稱:mautrix-telegram,代碼行數:32,代碼來源:parallel_file_transfer.py

示例4: download

# 需要導入模塊: from telethon import utils [as 別名]
# 或者: from telethon.utils import get_input_location [as 別名]
def download(self, file: TypeLocation, file_size: int, offset: int, limit: int
                 ) -> AsyncGenerator[bytes, None]:
        dc_id, location = utils.get_input_location(file)
        part_size = 512 * 1024
        first_part_cut = offset % part_size
        first_part = math.floor(offset / part_size)
        last_part_cut = part_size - (limit % part_size)
        last_part = math.ceil(limit / part_size)
        part_count = math.ceil(file_size / part_size)
        self.log.debug(f"Starting parallel download: chunks {first_part}-{last_part}"
                       f" of {part_count} {location!s}")
        request = GetFileRequest(location, offset=first_part * part_size, limit=part_size)

        return self._int_download(request, first_part, last_part, part_count, part_size, dc_id,
                                  first_part_cut, last_part_cut) 
開發者ID:tulir,項目名稱:tgfilestream,代碼行數:17,代碼來源:paralleltransfer.py

示例5: fetch_info

# 需要導入模塊: from telethon import utils [as 別名]
# 或者: from telethon.utils import get_input_location [as 別名]
def fetch_info(replied_user, event):
    """ Get details from the User object. """
    replied_user_profile_photos = await event.client(
        GetUserPhotosRequest(user_id=replied_user.user.id,
                             offset=42,
                             max_id=0,
                             limit=80))
    replied_user_profile_photos_count = "NaN."
    try:
        replied_user_profile_photos_count = replied_user_profile_photos.count
    except AttributeError as e:
        pass
    user_id = replied_user.user.id
    first_name = replied_user.user.first_name
    last_name = replied_user.user.last_name
    try:
        dc_id, location = get_input_location(replied_user.profile_photo)
    except Exception as e:
        dc_id = "Need a Profile Picture to check DC ID!"
        location = str(e)
    common_chat = replied_user.common_chats_count
    username = replied_user.user.username
    user_bio = replied_user.about
    is_bot = replied_user.user.bot
    restricted = replied_user.user.restricted
    verified = replied_user.user.verified
    photo = await event.client.download_profile_photo(user_id,
                                        TMP_DOWNLOAD_DIRECTORY +
                                                      str(user_id) + ".jpg",
                                                      download_big=True)
    first_name = first_name.replace(
        "\u2060", "") if first_name else ("")
    last_name = last_name.replace(
        "\u2060", "") if last_name else ("")
    username = "@{}".format(username) if username else (
        "This User has no Username")
    user_bio = "This User has no About" if not user_bio else user_bio
    if user_id != (await event.client.get_me()).id:
        common_chat = replied_user.common_chats_count
    else:
        common_chat = "I've seen them in... Wow. Are they stalking me? "
        common_chat += "They're in all the same places I am... oh. It's me."
        
    

    caption += f"<b>General Info OF {DEFAULTUSER}:</b> \n"
    caption += f"<a href=\"tg://user?id={user_id}\">{first_name}</a> \n"
    caption += f"<b>First Name</b>: {first_name} \n"
    caption += f"<b>ID</b>: <code>{user_id}</code> \n"
    caption += f"Last Name</b>: {last_name} \n"
    caption += f"<b>Username</b>: {username} \n"
    caption += f"DC ID: {dc_id}\n"
    caption += f"Number of PPs: {replied_user_profile_photos_count}\n"
    caption += f"Common Groups: {common_chat} \n \n"
    caption += f"<b>Bio</b>: \n<code>{user_bio}</code> \n"

    return caption 
開發者ID:mkaraniya,項目名稱:BotHub,代碼行數:59,代碼來源:wh.py


注:本文中的telethon.utils.get_input_location方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。