Coin telegraph:电报API 上传文件(telegraph gif)

我试图通过它的 API 上传一个文件,这是一个图像到电报页面。如果我发送一个链接,一个 URL 到已经上传到网络的文件,一切工作正常。

url_telegraph_API = 'https://api.telegra.ph/'
short_name = 'forecast_bot_help'
access_token = 'my_token'
path = 'Kak-byl-poluchen-prognoz-kursa-12-06-9'
just_image_url = 'https://www.import.io/wp-content/uploads/2021/02/manuel-t-xf1nszrKH_s- 
unsplash-scaled.jpg'
content_update = \
    [
    {'tag': 'strong', 'id': 'Node', 'children': ['''Конечно, никакого сигнала из Космоса не 
    было. 
    Да и ИИ, искуственный интеллект, - всего лишь генератор случайных чисел.'''], },
    {'tag': 'br'},
    {'tag': 'figure', 'children': [
    {'tag': 'img', 'attrs': {'src': just_image_url}},
    {'tag': 'figcaption'}
    ]},
    {"tag":"p","children":["test"]},
    {'tag': 'i', 'children':['''Но точность многих предсказаний курсов имееет такую же 
    ценность.''', 
     {'tag': 'i', 'children': [' В чем не сложно убедиться.']}]},
    {'tag': 'br'},
    {'tag': 'p', 'children': ['Поэтому улыбнитесь и двигайтесь дальше.']}
    ]
cont = json.dumps(content_update)
command = 'editPage?'
params = {
    'access_token': access_token,
    'path': path,
    'title': title,
    'author_name': author_name,
    'auth_url': auth_url,
    'content': cont, 
    'return_content': True
}
url = f'{url_telegraph_API}{command}'
create_page = requests.post(url, json=params)

我的问题是是否存在任

通过 API 将本地文件上传到 Telegraph

获取其 URL

我一直在尝试申请

def telegraph_file_upload(file):
    
    url_telegraph_API = 'https://api.telegra.ph/'
    command = 'upload'
    params = {'file': file}
    url = f'{url_telegraph_API}{command}'
    response = requests.get(url, params=params)
    
    return response
with open('test_image.jpg', 'rb') as f:
    file = f.read()
r = telegraph_file_upload(file)
print(r.content())

但是到目前为止还没有成功。知道吗?

1

最终它的工作原理

def telegraph_file_upload(path_to_file):
    '''
    Sends a file to telegra.ph storage and returns its url
    Works ONLY with 'gif', 'jpeg', 'jpg', 'png', 'mp4' 
    
    Parameters
    ---------------
    path_to_file -> str, path to a local file
    
    Return
    ---------------
    telegraph_url -> str, url of the file uploaded
    >>>telegraph_file_upload('test_image.jpg')
    https://telegra.ph/file/16016bafcf4eca0ce3e2b.jpg    
    >>>telegraph_file_upload('untitled.txt')
    error, txt-file can not be processed
    '''
    file_types = {'gif': 'image/gif', 'jpeg': 'image/jpeg', 'jpg': 'image/jpg', 'png': 'image/png', 'mp4': 'video/mp4'}
    file_ext = path_to_file.split('.')[-1]
    
    if file_ext in file_types:
        file_type = file_types[file_ext]
    else:
        return f'error, {file_ext}-file can not be proccessed' 
      
    with open(path_to_file, 'rb') as f:
        url = 'https://telegra.ph/upload'
        response = requests.post(url, files={'file': ('file', f, file_type)}, timeout=1)
    
    telegraph_url = json.loads(response.content)
    telegraph_url = telegraph_url[0]['src']
    telegraph_url = f'https://telegra.ph{telegraph_url}'
    
    return telegraph_url

通过 API 发送api.telagra.ph是我的错误。

应改用telagra.ph

本站系公益性非盈利分享网址,本文来自用户投稿,不代表边看边学立场,如若转载,请注明出处

(555)
Rid i books:nodejsDELETEauthorandGETbookstoshowallbooks withinfo
下一篇

相关推荐

  • css获取浏览器宽度:Welcome to my Website!

    CSS获取浏览器宽度的方法有两种:使用CSS3中的vw和vh来获取浏览器宽度…

    2023-05-18 11:12:00
    0 10 58
  • css参考手册:标题

    CSS参考手册是一本关于CSS语言的参考书,由W3C组织出版,包含了CSS语言的完整语法、属性、值和案例等。它提供了一个完整的CSS语言参考,可以帮助开发者快速学习和使用CSS语言,从而更好地创建网页。…

    2023-08-13 12:23:07
    0 72 68
  • css3 动画:Let's Make Some Magic With CSS3 Animations!

    CSS3动画是一种使用CSS3属性来创建动画的技术。它可以让你在不使用JavaScript的情况下实现复杂的动画效果,而且还能提高网页的性能。…

    2023-06-16 11:57:42
    0 14 17
  • css动态计算宽度:标题

    CSS动态计算宽度可以使用CSS的calc()函数来实现,该函数允许开发者在CSS中进行动态计算。例如:…

    2023-08-04 11:52:41
    0 48 78
  • css样式强制生效:标题

    CSS样式强制生效的方法有以下几种:使用 ! 属性:…

    2023-08-25 05:33:13
    0 69 92
  • css水平居中代码:标题

    示例示例使用`text-align: center;`可以实现元素水平居中,具体代码如下:另外也可以使用`margin: 0 auto;`来实现元素的水平居中,具体代码如下:…

    2023-06-09 10:04:08
    0 42 49
  • css折行让文本更加美观

    示例示例CSS折行是指在CSS中使用word-wrap属性来控制文本的折行,它允许长单词或URL地址换行显示,而不会被分割。word-wrap属性可以使用以下值:…

    2023-02-20 08:58:55
    0 51 75
  • css字体底部对齐:轻松学习CSS

    css字体底部对齐可以使用-align属性来实现,其中可以设置为bottom,代码如下:…

    2023-06-19 01:48:15
    0 53 18

发表评论

登录 后才能评论

评论列表(14条)