欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python處理application/json錯(cuò)誤的方法詳解

 更新時(shí)間:2025年02月24日 09:22:50   作者:Maybe_9527  
這篇文章主要為大家詳細(xì)介紹了python使用httpx_sse調(diào)用sse流式接口對(duì)響應(yīng)格式為application/json的錯(cuò)誤信息處理的相關(guān)知識(shí),需要的可以了解下

問題描述

調(diào)用sse流式接口使用httpx_sse的方式

				import httpx
				from httpx_sse import connect_sse
				# 省略無關(guān)代碼
				try:
                    with httpx.Client() as client:
                        with connect_sse(client, "GET", url, params=param) as event_source:
                            clear_textbox(response_textbox)
                            # 把 iter_sse() 迭代完, 就相當(dāng)于處理完了一次流式調(diào)用
                            for sse in event_source.iter_sse():
                                # 流式響應(yīng)中,每次響應(yīng)體的處理邏輯
                                print(f"generated_answer的值是: '{sse.data}'")
                                response = sse.data
                                if response != '':
                                    # self.response = response
                                    append_text(response_textbox, response)

                except httpx.RequestError as e:
                    print(f"請(qǐng)求錯(cuò)誤:{e}")
                except Exception as e:
                    print(f"發(fā)生了一個(gè)錯(cuò)誤:{e}")

httpx_sse的connet_sse源碼:

@contextmanager
def connect_sse(
    client: httpx.Client, method: str, url: str, **kwargs: Any
) -> Iterator[EventSource]:
    headers = kwargs.pop("headers", {})
    headers["Accept"] = "text/event-stream"
    headers["Cache-Control"] = "no-store"

    with client.stream(method, url, headers=headers, **kwargs) as response:
        yield EventSource(response)

可以看到connect_sse源碼中的headers的"Accept"設(shè)置了只接受"text/event-stream"流式結(jié)果,正常這么調(diào)用是沒錯(cuò)的。但是當(dāng)后端的流式接口因?yàn)?01權(quán)限問題等報(bào)錯(cuò)返回了"application/json"格式,如
{ “code”:401, “msg”:“登錄過期,請(qǐng)重新登錄”, “data”:null} 這樣的json格式結(jié)果時(shí),以上代碼就會(huì)報(bào)錯(cuò),因?yàn)樗皇?quot;text/event-stream"流式響應(yīng)結(jié)果頭。那么該怎么辦呢?

方案

重新寫一個(gè)自定義的connect_sse。

import httpx
from httpx_sse import EventSource
from typing import Any, Iterator
from contextlib import contextmanager
import json
# 自定義調(diào)用sse接口
    @contextmanager
    def custom_connect_sse(
            self, client: httpx.Client, method: str, url: str, **kwargs: Any
    ) -> Iterator[EventSource]:
        headers = kwargs.pop("headers", {})
        # 只有當(dāng)沒有指定Accept時(shí)才添加默認(rèn)值
        headers["Accept"] = "*/*"
        headers["Cache-Control"] = "no-store"

        with client.stream(method, url, headers=headers, **kwargs) as response:
            content_type = response.headers.get('content-type', '').lower()
            json_flag = False
            if 'text/event-stream' in content_type:
                # 處理SSE流
                yield json_flag, EventSource(response)
            elif 'application/json' in content_type:
                # yield response  # 在這里你可以決定如何進(jìn)一步處理這個(gè)JSON響應(yīng)
                # 讀取并合并所有文本塊
                text_data = ''.join([chunk for chunk in response.iter_text()])
                # 解析整個(gè)響應(yīng)體為JSON
                json_data = json.loads(text_data)
                json_flag = True
                yield json_flag, json_data

調(diào)用代碼

# 使用自定義的connect_sse函數(shù)
                try:
                    with httpx.Client() as client:
                        with self.custom_connect_sse(client, "GET", url, params=param, headers=headers) as (json_flag, event_source):
                            if json_flag:
                                code = event_source.get("code")
                                msg = event_source.get("msg")
                                print(f"Code: [code], Message: {msg}")
                            else:
                                full_answer = ""
                                clear_textbox(response_textbox)
                                for sse in event_source.iter_sse():
                                    print(f"generated_answer的值是: '{sse.data}'")
                                    response = sse.data
                                    if response:
                                        append_text(response_textbox, response)
                                        full_answer += response
                                user_record += reply + full_answer + "\n"
                                print(f"user_record:{user_record}")

                except httpx.RequestError as e:
                    print(f"請(qǐng)求錯(cuò)誤:{e}")
                except Exception as e:
                    print(f"發(fā)生了一個(gè)錯(cuò)誤:{e}")

關(guān)鍵步驟:

1.設(shè)置headers[“Accept”] = “/”,所有響應(yīng)頭都可以接收

2.content_type = response.headers.get(‘content-type’, ‘’).lower() 判斷響應(yīng)頭是流式還是json,并用json_flag記錄是否json標(biāo)識(shí),返回不同的結(jié)果。如果是json,則循環(huán)合并處理chunk塊,拼裝完整json返回結(jié)果(實(shí)測(cè)第一次就返回完整json結(jié)構(gòu)了,但是代碼得這么寫)。

3.使用自定義connect_sse方法時(shí),根據(jù)json_flag來分別處理成功調(diào)用流式結(jié)果還是異常的json結(jié)果。

到此這篇關(guān)于Python處理application/json錯(cuò)誤的方法詳解的文章就介紹到這了,更多相關(guān)Python處理application/json錯(cuò)誤內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • argparse?模塊簡(jiǎn)介

    argparse?模塊簡(jiǎn)介

    argparse是一個(gè)用來解析命令行參數(shù)的 Python 庫,它是 Python 標(biāo)準(zhǔn)庫的一部分,基于 python 2.7 的stdlib 代碼,這篇文章主要介紹了argparse?模塊詳解,需要的朋友可以參考下
    2023-02-02
  • Python實(shí)現(xiàn)擴(kuò)展內(nèi)置類型的方法分析

    Python實(shí)現(xiàn)擴(kuò)展內(nèi)置類型的方法分析

    這篇文章主要介紹了Python實(shí)現(xiàn)擴(kuò)展內(nèi)置類型的方法,結(jié)合實(shí)例形式分析了Python嵌入內(nèi)置類型擴(kuò)展及子類方式擴(kuò)展的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-10-10
  • pytorch permute維度轉(zhuǎn)換方法

    pytorch permute維度轉(zhuǎn)換方法

    今天小編就為大家分享一篇pytorch permute維度轉(zhuǎn)換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • python實(shí)現(xiàn)自動(dòng)登錄人人網(wǎng)并采集信息的方法

    python實(shí)現(xiàn)自動(dòng)登錄人人網(wǎng)并采集信息的方法

    這篇文章主要介紹了python實(shí)現(xiàn)自動(dòng)登錄人人網(wǎng)并采集信息的方法,涉及Python模擬登陸及正則匹配的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • python解壓縮文件或文件夾兩種常見方式(附代碼)

    python解壓縮文件或文件夾兩種常見方式(附代碼)

    這篇文章主要介紹了python解壓縮文件或文件夾兩種常見方式,Python的zipfile和shutil模塊提供了強(qiáng)大的文件和文件夾壓縮與解壓縮功能,zipfile模塊適合精細(xì)控制,而shutil模塊則快速簡(jiǎn)單,文中提供了詳細(xì)的代碼示例,需要的朋友可以參考下
    2025-04-04
  • Python制作微信機(jī)器人教程詳解

    Python制作微信機(jī)器人教程詳解

    這篇文章主要介紹了Python如何實(shí)現(xiàn)微信機(jī)器人,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-12-12
  • 動(dòng)態(tài)設(shè)置django的model field的默認(rèn)值操作步驟

    動(dòng)態(tài)設(shè)置django的model field的默認(rèn)值操作步驟

    這篇文章主要介紹了動(dòng)態(tài)設(shè)置django的model field的默認(rèn)值操作步驟,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Flask框架實(shí)現(xiàn)給視圖函數(shù)增加裝飾器操作示例

    Flask框架實(shí)現(xiàn)給視圖函數(shù)增加裝飾器操作示例

    這篇文章主要介紹了Flask框架實(shí)現(xiàn)給視圖函數(shù)增加裝飾器操作,結(jié)合實(shí)例形式分析了flask框架視圖添加裝飾器的具體操作方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2018-07-07
  • Python 文件數(shù)據(jù)讀寫的具體實(shí)現(xiàn)

    Python 文件數(shù)據(jù)讀寫的具體實(shí)現(xiàn)

    這篇文章主要介紹了Python 文件數(shù)據(jù)讀寫的具體實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • python 返回列表中某個(gè)值的索引方法

    python 返回列表中某個(gè)值的索引方法

    今天小編就為大家分享一篇python 返回列表中某個(gè)值的索引方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11

最新評(píng)論