本文整理匯總了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
示例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
示例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)
示例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)
示例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