mirror of
https://github.com/csunny/DB-GPT.git
synced 2025-07-27 13:57:46 +00:00
68 lines
1.8 KiB
Python
68 lines
1.8 KiB
Python
"""Agents: single agents about CodeAssistantAgent?
|
|
|
|
Examples:
|
|
|
|
Execute the following command in the terminal:
|
|
Set env params.
|
|
.. code-block:: shell
|
|
|
|
export OPENAI_API_KEY=sk-xx
|
|
export OPENAI_API_BASE=https://xx:80/v1
|
|
|
|
run example.
|
|
..code-block:: shell
|
|
python examples/agents/single_agent_dialogue_example.py
|
|
"""
|
|
|
|
import asyncio
|
|
import os
|
|
|
|
from dbgpt.agent import AgentContext, AgentMemory, LLMConfig, UserProxyAgent
|
|
from dbgpt.agent.expand.data_scientist_agent import DataScientistAgent
|
|
from dbgpt.agent.resource import SQLiteDBResource
|
|
from dbgpt.configs.model_config import ROOT_PATH
|
|
from dbgpt.util.tracer import initialize_tracer
|
|
|
|
test_plugin_dir = os.path.join(ROOT_PATH, "test_files")
|
|
|
|
initialize_tracer("/tmp/agent_trace.jsonl", create_system_app=True)
|
|
|
|
|
|
async def main():
|
|
from dbgpt.model.proxy.llms.siliconflow import SiliconFlowLLMClient
|
|
|
|
llm_client = SiliconFlowLLMClient(
|
|
model_alias=os.getenv(
|
|
"SILICONFLOW_MODEL_VERSION", "Qwen/Qwen2.5-Coder-32B-Instruct"
|
|
),
|
|
)
|
|
context: AgentContext = AgentContext(conv_id="test456")
|
|
|
|
agent_memory = AgentMemory()
|
|
agent_memory.gpts_memory.init(conv_id="test456")
|
|
|
|
sqlite_resource = SQLiteDBResource("SQLite Database", f"{test_plugin_dir}/dbgpt.db")
|
|
user_proxy = await UserProxyAgent().bind(agent_memory).bind(context).build()
|
|
|
|
sql_boy = (
|
|
await DataScientistAgent()
|
|
.bind(context)
|
|
.bind(LLMConfig(llm_client=llm_client))
|
|
.bind(sqlite_resource)
|
|
.bind(agent_memory)
|
|
.build()
|
|
)
|
|
|
|
await user_proxy.initiate_chat(
|
|
recipient=sql_boy,
|
|
reviewer=user_proxy,
|
|
message="当前库有那些表",
|
|
)
|
|
|
|
## dbgpt-vis message infos
|
|
print(await agent_memory.gpts_memory.app_link_chat_message("test456"))
|
|
|
|
|
|
if __name__ == "__main__":
|
|
asyncio.run(main())
|