import os
import requests
import json
import time
from requests.exceptions import RequestException
API_KEY=YOUR_API_KEY
def ds_infer(input,model="DeepSeek-R1"):
    """
    发送请求到DeepSeek API，如果失败则自动重试
    """
    api_key = API_KEY
    headers = {
        'Content-Type': 'application/json',
        'Authorization': 'Bearer ' + api_key,
        'SOFA-TraceId': '0b46977c17296519321548915ef847',
        'SOFA-RpcId': '0.1',
    }
    json_data = {
        'model': model,
        'messages': [
            {
                'role': 'user',
                'content': input,
            },
        ],
    }
    
    # 重试配置
    max_retries = 4  # 最大重试次数
    retry_delay = 10   # 初始重试延迟(秒)
    backoff_factor = 2  # 退避因子
    for attempt in range(max_retries + 1):  # +1 包含首次尝试
        try:
            response = requests.post(
                URL,
                headers=headers,
                json=json_data,
                # timeout=(10, 15)  # 建议启用超时
            )
            response.raise_for_status()  # 检查HTTP状态码
            
            # 解析JSON响应
            response_data = response.json()
            # 验证响应数据结构
            if not all(key in response_data for key in ["choices", "model"]):
                raise ValueError("Invalid API response structure")
                
            # 提取内容
            content =response_data["choices"][0]["message"]["content"]
            return content
            
        except RequestException as e:
            # 可重试异常：网络错误或5xx服务器错误
            if attempt < max_retries:
                current_delay = retry_delay * (backoff_factor ** attempt)
                print(f"请求失败，准备重试 ({attempt+1}/{max_retries})，等待 {current_delay:.1f}秒... 错误: {str(e)}")
                time.sleep(current_delay)
            else:
                print(f"API请求失败（{max_retries}次重试后）: {str(e)}")
                return "Error"   
        except (ValueError, KeyError, IndexError) as e:
            # 数据处理错误（通常不可重试）
            print(f"数据处理失败: {str(e)}")
            return "Error"     
        except Exception as e:
            # 其他未预期错误
            print(f"未预期错误: {str(e)}")
            return "Error"
    
    return "Error"  # 最终回退
def extract_json_dict(s):
    """
    从字符串中提取第一个有效的JSON字典。
    返回字典对象或None（若未找到）。
    """
    stack = []  # 用于跟踪花括号的嵌套层次
    start_index = -1  # 记录字典起始位置
    in_string = False  # 标记是否在双引号字符串内
    escape = False  # 标记转义字符

    for i, char in enumerate(s):
        # 处理转义字符（仅字符串内有效）
        if in_string and char == '\\' and not escape:
            escape = True
            continue

        # 处理双引号（字符串边界）
        if char == '"' and not escape:
            in_string = not in_string

        # 重置转义标记
        if escape:
            escape = False

        # 非字符串状态下处理花括号
        if not in_string:
            if char == '{':
                stack.append(i)  # 记录左括号位置
                if start_index == -1:
                    start_index = i  # 标记字典起始位置
            elif char == '}':
                if stack:
                    stack.pop()  # 弹出匹配的左括号
                    # 当栈为空时，说明找到完整字典结构
                    if not stack and start_index != -1:
                        # 截取候选JSON子串
                        candidate = s[start_index:i+1]
                        try:
                            # 尝试解析为字典
                            result = json.loads(candidate)
                            if isinstance(result, dict):
                                return result
                        except json.JSONDecodeError:
                            pass  # 解析失败则继续
                        start_index = -1  # 重置起始位置
                else:
                    start_index = -1  # 多余右括号，重置状态

    return None  # 未找到有效字典