2026-01-11 11:45:47,403 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 11:45:48,617 - app.services.data_fetcher_service - INFO - 📝 [数据获取] 股票代码格式化: 300750 -> 300750.SZ 2026-01-11 11:45:48,755 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=数据源连接成功, Progress=5% 2026-01-11 11:45:51,074 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 11:45:52,716 - app.clients.tushare_cn_client - INFO - 🐛 [DEBUG] get_income_statement called with symbol: '300750.SZ' 2026-01-11 11:45:52,716 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 income() 获取利润表, symbol=300750.SZ 2026-01-11 11:45:52,920 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] income() 完成, 返回 52 行, 耗时: 0.20秒 2026-01-11 11:45:53,990 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_income_statement: 跳过 52 条已存在的数据, 准备插入 0 条 2026-01-11 11:45:53,991 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_income_statement: 所有数据已存在,无需更新。 2026-01-11 11:45:53,997 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=利润表获取完成 (40行), Progress=25% 2026-01-11 11:45:54,832 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 11:45:57,983 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 balancesheet() 获取资产负债表, symbol=300750.SZ 2026-01-11 11:45:58,134 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] balancesheet() 完成, 返回 60 行, 耗时: 0.15秒 2026-01-11 11:45:59,867 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_balance_sheet: 跳过 60 条已存在的数据, 准备插入 0 条 2026-01-11 11:45:59,868 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_balance_sheet: 所有数据已存在,无需更新。 2026-01-11 11:45:59,870 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=资产负债表获取完成 (38行), Progress=50% 2026-01-11 11:46:00,962 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 11:46:02,228 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 cashflow() 获取现金流量表, symbol=300750.SZ 2026-01-11 11:46:02,372 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] cashflow() 完成, 返回 51 行, 耗时: 0.14秒 2026-01-11 11:46:02,731 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_cash_flow: 跳过 51 条已存在的数据, 准备插入 0 条 2026-01-11 11:46:02,731 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_cash_flow: 所有数据已存在,无需更新。 2026-01-11 11:46:02,733 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=现金流量表获取完成 (38行), Progress=75% 2026-01-11 11:46:03,939 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取市场指标..., Progress=78% 2026-01-11 11:46:07,160 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_daily_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 11:46:07,160 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_daily_basic: 所有数据已存在,无需更新。 2026-01-11 11:46:09,420 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stock_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 11:46:09,420 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stock_basic: 所有数据已存在,无需更新。 2026-01-11 11:46:12,553 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stk_holdernumber: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 11:46:12,554 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stk_holdernumber: 所有数据已存在,无需更新。 2026-01-11 11:46:12,554 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=市场指标获取完成, Progress=85% 2026-01-11 11:46:14,701 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取分红数据..., Progress=87% 2026-01-11 11:46:17,140 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取回购数据..., Progress=90% 2026-01-11 11:46:20,568 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在获取员工数据..., Progress=93% 2026-01-11 11:46:23,586 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=正在处理统计信息..., Progress=96% 2026-01-11 11:46:25,289 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=23, Msg=数据获取完成, Progress=100% 2026-01-11 11:49:55,669 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 11:49:58,132 - app.services.data_fetcher_service - INFO - 📝 [数据获取] 股票代码格式化: 300750 -> 300750.SZ 2026-01-11 11:49:58,212 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=数据源连接成功, Progress=5% 2026-01-11 11:49:59,473 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 11:50:02,031 - app.clients.tushare_cn_client - INFO - 🐛 [DEBUG] get_income_statement called with symbol: '300750.SZ' 2026-01-11 11:50:02,032 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 income() 获取利润表, symbol=300750.SZ 2026-01-11 11:50:02,221 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] income() 完成, 返回 52 行, 耗时: 0.19秒 2026-01-11 11:50:03,736 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_income_statement: 跳过 52 条已存在的数据, 准备插入 0 条 2026-01-11 11:50:03,736 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_income_statement: 所有数据已存在,无需更新。 2026-01-11 11:50:03,742 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=利润表获取完成 (40行), Progress=25% 2026-01-11 11:50:06,644 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 11:50:08,617 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 balancesheet() 获取资产负债表, symbol=300750.SZ 2026-01-11 11:50:08,765 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] balancesheet() 完成, 返回 60 行, 耗时: 0.15秒 2026-01-11 11:50:33,205 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_balance_sheet: 跳过 60 条已存在的数据, 准备插入 0 条 2026-01-11 11:50:33,205 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_balance_sheet: 所有数据已存在,无需更新。 2026-01-11 11:50:33,215 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=资产负债表获取完成 (38行), Progress=50% 2026-01-11 11:50:35,816 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 11:50:37,038 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 cashflow() 获取现金流量表, symbol=300750.SZ 2026-01-11 11:50:37,181 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] cashflow() 完成, 返回 51 行, 耗时: 0.14秒 2026-01-11 11:50:38,707 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_cash_flow: 跳过 51 条已存在的数据, 准备插入 0 条 2026-01-11 11:50:38,707 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_cash_flow: 所有数据已存在,无需更新。 2026-01-11 11:50:38,710 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=现金流量表获取完成 (38行), Progress=75% 2026-01-11 11:50:40,082 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取市场指标..., Progress=78% 2026-01-11 11:50:43,032 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_daily_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 11:50:43,033 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_daily_basic: 所有数据已存在,无需更新。 2026-01-11 11:50:45,200 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stock_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 11:50:45,200 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stock_basic: 所有数据已存在,无需更新。 2026-01-11 11:50:46,206 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stk_holdernumber: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 11:50:46,206 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stk_holdernumber: 所有数据已存在,无需更新。 2026-01-11 11:50:46,207 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=市场指标获取完成, Progress=85% 2026-01-11 11:50:48,598 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取分红数据..., Progress=87% 2026-01-11 11:50:49,811 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取回购数据..., Progress=90% 2026-01-11 11:50:51,191 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在获取员工数据..., Progress=93% 2026-01-11 11:50:56,398 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=正在处理统计信息..., Progress=96% 2026-01-11 11:50:57,709 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=24, Msg=数据获取完成, Progress=100% 2026-01-11 11:51:33,622 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 宁德时代 2026-01-11 11:51:33,804 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-3-flash-preview 进行股票搜索 2026-01-11 11:51:33,810 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 11:51:44,168 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-3-flash-preview:generateContent "HTTP/1.1 200 OK" 2026-01-11 11:51:44,204 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 10.40秒, Tokens: prompt=250, completion=60, total=310 2026-01-11 11:51:44,204 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 2 个结果, 总耗时: 10.58秒 2026-01-11 11:59:04,507 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 宁德时代 2026-01-11 11:59:04,521 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 11:59:04,532 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 11:59:08,512 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 11:59:08,534 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.01秒, Tokens: prompt=165, completion=85, total=250 2026-01-11 11:59:08,534 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 2 个结果, 总耗时: 4.02秒 2026-01-11 12:00:05,581 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 宁德时代 2026-01-11 12:00:05,589 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 12:00:05,594 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 12:00:08,993 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 12:00:09,063 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.47秒, Tokens: prompt=165, completion=85, total=250 2026-01-11 12:00:09,063 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 2 个结果, 总耗时: 3.48秒 2026-01-11 12:00:20,238 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 宁德时代 2026-01-11 12:00:20,239 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 12:00:20,240 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 12:00:23,618 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 12:00:23,645 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.41秒, Tokens: prompt=165, completion=85, total=250 2026-01-11 12:00:23,645 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 2 个结果, 总耗时: 3.41秒 2026-01-11 12:00:43,588 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 12:00:45,312 - app.services.data_fetcher_service - INFO - 📝 [数据获取] 股票代码格式化: 300750 -> 300750.SZ 2026-01-11 12:00:45,416 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=数据源连接成功, Progress=5% 2026-01-11 12:00:46,272 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 12:00:46,759 - app.clients.tushare_cn_client - INFO - 🐛 [DEBUG] get_income_statement called with symbol: '300750.SZ' 2026-01-11 12:00:46,759 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 income() 获取利润表, symbol=300750.SZ 2026-01-11 12:00:46,960 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] income() 完成, 返回 52 行, 耗时: 0.20秒 2026-01-11 12:00:47,759 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_income_statement: 跳过 52 条已存在的数据, 准备插入 0 条 2026-01-11 12:00:47,759 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_income_statement: 所有数据已存在,无需更新。 2026-01-11 12:00:47,765 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=利润表获取完成 (40行), Progress=25% 2026-01-11 12:00:48,173 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 12:00:49,036 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 balancesheet() 获取资产负债表, symbol=300750.SZ 2026-01-11 12:00:49,197 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] balancesheet() 完成, 返回 60 行, 耗时: 0.16秒 2026-01-11 12:00:49,900 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_balance_sheet: 跳过 60 条已存在的数据, 准备插入 0 条 2026-01-11 12:00:49,900 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_balance_sheet: 所有数据已存在,无需更新。 2026-01-11 12:00:49,902 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=资产负债表获取完成 (38行), Progress=50% 2026-01-11 12:00:50,620 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 12:00:51,395 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 cashflow() 获取现金流量表, symbol=300750.SZ 2026-01-11 12:00:51,535 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] cashflow() 完成, 返回 51 行, 耗时: 0.14秒 2026-01-11 12:00:52,356 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_cash_flow: 跳过 51 条已存在的数据, 准备插入 0 条 2026-01-11 12:00:52,357 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_cash_flow: 所有数据已存在,无需更新。 2026-01-11 12:00:52,359 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=现金流量表获取完成 (38行), Progress=75% 2026-01-11 12:00:52,655 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取市场指标..., Progress=78% 2026-01-11 12:00:54,258 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_daily_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 12:00:54,259 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_daily_basic: 所有数据已存在,无需更新。 2026-01-11 12:00:55,302 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stock_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 12:00:55,302 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stock_basic: 所有数据已存在,无需更新。 2026-01-11 12:00:57,229 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stk_holdernumber: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 12:00:57,230 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stk_holdernumber: 所有数据已存在,无需更新。 2026-01-11 12:00:57,230 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=市场指标获取完成, Progress=85% 2026-01-11 12:01:04,175 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取分红数据..., Progress=87% 2026-01-11 12:01:07,425 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取回购数据..., Progress=90% 2026-01-11 12:01:09,285 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在获取员工数据..., Progress=93% 2026-01-11 12:01:11,661 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=正在处理统计信息..., Progress=96% 2026-01-11 12:01:12,931 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=25, Msg=数据获取完成, Progress=100% 2026-01-11 12:03:25,453 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 宁德时代 2026-01-11 12:03:25,463 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 12:03:25,469 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 12:03:28,867 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 12:03:28,937 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.47秒, Tokens: prompt=165, completion=85, total=250 2026-01-11 12:03:28,938 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 2 个结果, 总耗时: 3.48秒 2026-01-11 12:03:36,309 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 12:03:37,044 - app.services.data_fetcher_service - INFO - 📝 [数据获取] 股票代码格式化: 300750 -> 300750.SZ 2026-01-11 12:03:37,099 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=数据源连接成功, Progress=5% 2026-01-11 12:03:38,169 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 12:03:39,085 - app.clients.tushare_cn_client - INFO - 🐛 [DEBUG] get_income_statement called with symbol: '300750.SZ' 2026-01-11 12:03:39,085 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 income() 获取利润表, symbol=300750.SZ 2026-01-11 12:03:39,345 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] income() 完成, 返回 52 行, 耗时: 0.26秒 2026-01-11 12:03:39,864 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_income_statement: 跳过 52 条已存在的数据, 准备插入 0 条 2026-01-11 12:03:39,864 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_income_statement: 所有数据已存在,无需更新。 2026-01-11 12:03:39,874 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=利润表获取完成 (40行), Progress=25% 2026-01-11 12:03:40,581 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 12:03:42,076 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 balancesheet() 获取资产负债表, symbol=300750.SZ 2026-01-11 12:03:42,245 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] balancesheet() 完成, 返回 60 行, 耗时: 0.16秒 2026-01-11 12:03:43,042 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_balance_sheet: 跳过 60 条已存在的数据, 准备插入 0 条 2026-01-11 12:03:43,043 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_balance_sheet: 所有数据已存在,无需更新。 2026-01-11 12:03:43,046 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=资产负债表获取完成 (38行), Progress=50% 2026-01-11 12:03:44,648 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 12:03:45,386 - app.clients.tushare_cn_client - INFO - 🔍 [Tushare API] 调用 cashflow() 获取现金流量表, symbol=300750.SZ 2026-01-11 12:03:45,535 - app.clients.tushare_cn_client - INFO - ✅ [Tushare API] cashflow() 完成, 返回 51 行, 耗时: 0.15秒 2026-01-11 12:03:46,986 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_cash_flow: 跳过 51 条已存在的数据, 准备插入 0 条 2026-01-11 12:03:46,986 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_cash_flow: 所有数据已存在,无需更新。 2026-01-11 12:03:46,988 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=现金流量表获取完成 (38行), Progress=75% 2026-01-11 12:03:47,888 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取市场指标..., Progress=78% 2026-01-11 12:03:51,744 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_daily_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 12:03:51,745 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_daily_basic: 所有数据已存在,无需更新。 2026-01-11 12:03:52,685 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stock_basic: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 12:03:52,688 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stock_basic: 所有数据已存在,无需更新。 2026-01-11 12:03:53,710 - app.clients.tushare_cn_client - INFO - ⏭️ [数据库] 表 tushare_stk_holdernumber: 跳过 1 条已存在的数据, 准备插入 0 条 2026-01-11 12:03:53,711 - app.clients.tushare_cn_client - INFO - ✅ [数据库] 表 tushare_stk_holdernumber: 所有数据已存在,无需更新。 2026-01-11 12:03:53,711 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=市场指标获取完成, Progress=85% 2026-01-11 12:03:55,031 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取分红数据..., Progress=87% 2026-01-11 12:03:55,940 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取回购数据..., Progress=90% 2026-01-11 12:03:56,705 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在获取员工数据..., Progress=93% 2026-01-11 12:04:00,239 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=正在处理统计信息..., Progress=96% 2026-01-11 12:04:01,129 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=26, Msg=数据获取完成, Progress=100% 2026-01-11 12:57:47,122 - app.main - INFO - 🔍 [搜索] 开始搜索股票: AAPL 2026-01-11 12:57:47,263 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 12:57:47,264 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 12:57:51,593 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 12:57:51,620 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.36秒, Tokens: prompt=164, completion=62, total=226 2026-01-11 12:57:51,620 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.50秒 2026-01-11 12:58:04,131 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 12:58:05,427 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=数据源连接成功, Progress=5% 2026-01-11 12:58:06,418 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 12:58:10,730 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_income_statement: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:10,783 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=利润表获取完成 (5行), Progress=25% 2026-01-11 12:58:11,387 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 12:58:14,923 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_balance_sheet: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:14,958 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=资产负债表获取完成 (5行), Progress=50% 2026-01-11 12:58:15,598 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 12:58:19,119 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_cash_flow: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:19,153 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=现金流量表获取完成 (5行), Progress=75% 2026-01-11 12:58:20,237 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取市场指标..., Progress=78% 2026-01-11 12:58:22,585 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=市场指标获取完成, Progress=85% 2026-01-11 12:58:23,290 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取分红数据..., Progress=87% 2026-01-11 12:58:24,959 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_dividend: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:25,912 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_dividend: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:26,840 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_dividend: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:27,590 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_dividend: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:29,663 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_dividend: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:29,696 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取回购数据..., Progress=90% 2026-01-11 12:58:33,767 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_repurchase: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:35,802 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_repurchase: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:36,947 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_repurchase: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:37,937 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_repurchase: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:38,590 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_repurchase: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:38,781 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在获取员工数据..., Progress=93% 2026-01-11 12:58:40,017 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_employee: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:41,200 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_employee: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:42,108 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_employee: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:43,013 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_employee: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:45,127 - app.clients.ifind_int_client - ERROR - Error saving to ifind_int_employee: value too long for type character varying(8) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/clients/ifind_int_client.py", line 156, in _save_df_to_wide_table cur.executemany(insert_sql, data_tuples) ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.StringDataRightTruncation: value too long for type character varying(8) 2026-01-11 12:58:45,164 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=正在处理统计信息..., Progress=96% 2026-01-11 12:58:45,774 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=27, Msg=数据获取完成, Progress=100% 2026-01-11 12:59:04,411 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 12:59:06,455 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 12:59:12,657 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 12:59:12,690 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 12:59:13,757 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 12:59:13,757 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=数据源连接成功, Progress=5% 2026-01-11 12:59:14,539 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 12:59:15,392 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 12:59:15,430 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 12:59:17,871 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 12:59:17,871 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 12:59:45,670 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 12:59:46,262 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 12:59:51,668 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 12:59:51,669 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 12:59:52,369 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=利润表获取完成 (10行), Progress=25% 2026-01-11 12:59:54,510 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 12:59:55,811 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 12:59:56,051 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 12:59:58,039 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 12:59:58,040 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:00:22,167 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:00:22,817 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:00:30,258 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:00:30,261 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:00:31,488 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=资产负债表获取完成 (10行), Progress=50% 2026-01-11 13:00:32,114 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 13:00:32,800 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:00:32,834 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:00:35,564 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:00:35,564 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:00:57,471 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:00:59,099 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:01:03,826 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:01:03,827 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:01:04,098 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=现金流量表获取完成 (10行), Progress=75% 2026-01-11 13:01:06,609 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取市场指标..., Progress=78% 2026-01-11 13:01:07,384 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:01:07,420 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:01:11,057 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:01:11,058 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:01:39,585 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:01:40,508 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:01:45,091 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:01:45,091 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:01:45,573 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=市场指标获取完成, Progress=85% 2026-01-11 13:01:48,482 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取分红数据..., Progress=87% 2026-01-11 13:01:49,509 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:01:49,571 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:01:53,489 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:01:53,489 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:02:16,423 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:02:17,466 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:02:23,914 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:02:23,922 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:02:27,017 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:02:27,139 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:02:29,506 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:02:29,506 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:02:53,208 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:02:53,770 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:02:58,094 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:02:58,095 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:02:59,289 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取回购数据..., Progress=90% 2026-01-11 13:03:00,718 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:03:00,780 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:03:03,616 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:03:03,617 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:03:22,678 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:03:24,109 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:03:28,398 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:03:28,399 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:03:29,011 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在获取员工数据..., Progress=93% 2026-01-11 13:03:32,157 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:03:32,313 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:03:35,432 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:03:35,433 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:04:06,049 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:04:42,105 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:04:47,812 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:04:47,812 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:04:48,709 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=正在处理统计信息..., Progress=96% 2026-01-11 13:04:49,804 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=28, Msg=数据获取完成, Progress=100% 2026-01-11 13:10:32,945 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果公司 2026-01-11 13:10:33,006 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 13:10:33,007 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:10:36,067 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:10:36,250 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.24秒, Tokens: prompt=164, completion=41, total=205 2026-01-11 13:10:36,250 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 3.30秒 2026-01-11 13:10:43,800 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 13:10:44,625 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=数据源连接成功, Progress=5% 2026-01-11 13:10:45,570 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 13:10:48,599 - app.clients.ifind_int_client - INFO - 🆕 [Database] Creating table ifind_int_income_statement... 2026-01-11 13:10:49,088 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=利润表获取完成 (5行), Progress=25% 2026-01-11 13:10:49,377 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 13:10:51,567 - app.clients.ifind_int_client - INFO - 🆕 [Database] Creating table ifind_int_balance_sheet... 2026-01-11 13:10:52,644 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=资产负债表获取完成 (5行), Progress=50% 2026-01-11 13:10:53,802 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 13:10:56,542 - app.clients.ifind_int_client - INFO - 🆕 [Database] Creating table ifind_int_cash_flow... 2026-01-11 13:10:57,461 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=现金流量表获取完成 (5行), Progress=75% 2026-01-11 13:10:58,068 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取市场指标..., Progress=78% 2026-01-11 13:11:00,709 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=市场指标获取完成, Progress=85% 2026-01-11 13:11:01,969 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取分红数据..., Progress=87% 2026-01-11 13:11:04,053 - app.clients.ifind_int_client - INFO - 🆕 [Database] Creating table ifind_int_dividend... 2026-01-11 13:11:10,496 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取回购数据..., Progress=90% 2026-01-11 13:11:13,407 - app.clients.ifind_int_client - INFO - 🆕 [Database] Creating table ifind_int_repurchase... 2026-01-11 13:11:17,482 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在获取员工数据..., Progress=93% 2026-01-11 13:11:18,914 - app.clients.ifind_int_client - INFO - 🆕 [Database] Creating table ifind_int_employee... 2026-01-11 13:11:25,165 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=正在处理统计信息..., Progress=96% 2026-01-11 13:11:26,011 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=29, Msg=数据获取完成, Progress=100% 2026-01-11 13:12:03,786 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果公司 2026-01-11 13:12:03,792 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-3-flash-preview 进行股票搜索 2026-01-11 13:12:03,794 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:12:08,779 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-3-flash-preview:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:12:08,792 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 5.00秒, Tokens: prompt=297, completion=23, total=320 2026-01-11 13:12:08,792 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 5.00秒 2026-01-11 13:12:36,444 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 13:12:38,125 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 13:12:39,910 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 13:12:40,145 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 13:12:40,693 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 13:12:40,693 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=数据源连接成功, Progress=5% 2026-01-11 13:12:41,767 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取利润表数据..., Progress=10% 2026-01-11 13:12:43,203 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:12:43,382 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:12:44,634 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:12:46,618 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:12:46,622 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:12:46,622 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:12:47,254 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:13:05,304 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:13:05,307 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:13:05,878 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:13:05,878 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:13:07,612 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:13:11,123 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:13:12,009 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:13:12,010 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:13:12,566 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=利润表获取完成 (10行), Progress=25% 2026-01-11 13:13:14,432 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取资产负债表数据..., Progress=30% 2026-01-11 13:13:15,988 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:13:16,083 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:13:17,200 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:13:17,935 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:13:17,935 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:13:17,935 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:13:18,688 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:13:39,188 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:13:39,196 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:13:39,853 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:13:39,854 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:13:40,540 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:13:42,325 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:13:43,141 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:13:43,142 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:13:44,741 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=资产负债表获取完成 (10行), Progress=50% 2026-01-11 13:13:45,029 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取现金流量表数据..., Progress=55% 2026-01-11 13:13:45,758 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:13:45,845 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:13:47,459 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:13:48,233 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:13:48,234 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:13:48,234 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:13:49,024 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:14:07,425 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:14:07,433 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:14:07,995 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:14:07,995 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:14:08,474 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:14:10,763 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:14:13,387 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:14:13,388 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:14:14,707 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=现金流量表获取完成 (10行), Progress=75% 2026-01-11 13:14:16,639 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取市场指标..., Progress=78% 2026-01-11 13:14:17,086 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:14:17,329 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:14:18,303 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:14:19,911 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:14:19,912 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:14:19,912 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:14:21,551 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:14:44,941 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:14:44,945 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:14:45,513 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:14:45,514 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:14:45,990 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:14:48,901 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:14:49,421 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:14:49,422 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:14:50,089 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=市场指标获取完成, Progress=85% 2026-01-11 13:14:51,243 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取分红数据..., Progress=87% 2026-01-11 13:14:53,521 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:14:53,583 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:14:54,563 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:14:56,003 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:14:56,003 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:14:56,003 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:14:57,097 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:15:15,678 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:15:15,743 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:15:16,343 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:15:16,343 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:15:16,882 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:15:19,450 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:15:20,212 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:15:20,213 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:15:21,472 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:15:21,947 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:15:22,974 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:15:24,699 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:15:24,701 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:15:24,701 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:15:25,557 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:15:48,402 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:15:48,408 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:15:48,992 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:15:48,992 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:15:49,537 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:15:53,243 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:15:54,472 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:15:54,472 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:15:56,157 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取回购数据..., Progress=90% 2026-01-11 13:15:56,967 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:15:57,529 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:15:58,535 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:16:03,967 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:16:03,968 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:16:03,968 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:16:05,136 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:16:23,995 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:16:24,005 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:16:24,720 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:16:24,720 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:16:25,257 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:16:27,891 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:16:28,612 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:16:28,612 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:16:29,084 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在获取员工数据..., Progress=93% 2026-01-11 13:16:30,087 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 13:16:30,146 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 13:16:31,162 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 13:16:33,231 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 13:16:33,232 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 13:16:33,232 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 13:16:34,499 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 13:16:58,065 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 13:16:58,073 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 13:16:58,682 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 13:16:58,683 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 13:16:59,181 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 13:17:01,161 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 13:17:01,830 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 13:17:01,830 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 13:17:03,238 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=正在处理统计信息..., Progress=96% 2026-01-11 13:17:04,206 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=30, Msg=数据获取完成, Progress=100% 2026-01-11 13:17:40,291 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果 2026-01-11 13:17:40,302 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 13:17:40,307 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:17:43,895 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:17:43,912 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.61秒, Tokens: prompt=163, completion=41, total=204 2026-01-11 13:17:43,912 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 3.62秒 2026-01-11 13:21:40,401 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果 2026-01-11 13:21:40,607 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 13:21:40,609 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:21:43,517 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:21:43,533 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 2.93秒, Tokens: prompt=163, completion=67, total=230 2026-01-11 13:21:43,533 - app.main - ERROR - ❌ [搜索] 搜索失败: Expecting value: line 1 column 1 (char 0), 耗时: 3.13秒 2026-01-11 13:21:50,070 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果公司 2026-01-11 13:21:50,071 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 13:21:50,071 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:21:54,239 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:21:54,256 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.18秒, Tokens: prompt=165, completion=70, total=235 2026-01-11 13:21:54,256 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.19秒 2026-01-11 13:22:31,039 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果公司 2026-01-11 13:22:31,173 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 13:22:31,174 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:22:34,945 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:22:35,049 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.88秒, Tokens: prompt=164, completion=41, total=205 2026-01-11 13:22:35,050 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.01秒 2026-01-11 13:27:04,387 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 英伟达 2026-01-11 13:27:04,393 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash 进行股票搜索 2026-01-11 13:27:04,399 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 13:27:07,007 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 13:27:07,019 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 2.63秒, Tokens: prompt=165, completion=47, total=212 2026-01-11 13:27:07,019 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 2.63秒 2026-01-11 14:35:52,113 - app.main - INFO - 🔍 [搜索] 开始搜索股票: app 2026-01-11 14:35:52,139 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 14:35:52,153 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 14:35:56,588 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 14:35:56,611 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.47秒, Tokens: prompt=164, completion=68, total=232 2026-01-11 14:35:56,613 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.49秒 2026-01-11 14:36:08,928 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 14:36:12,521 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 14:36:16,223 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 14:36:16,253 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 14:36:16,743 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 14:36:16,745 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=数据源连接成功, Progress=5% 2026-01-11 14:36:20,091 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在连接 Bloomberg 终端并同步所有数据(Basic, Currency, Price)..., Progress=10% 2026-01-11 14:36:23,298 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:36:23,365 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:36:25,752 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:36:26,545 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:36:26,546 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:36:26,546 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:36:27,660 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:36:49,193 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:36:49,195 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:36:49,887 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:36:49,887 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:36:50,445 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:36:53,854 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:36:55,264 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:36:55,265 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:36:57,582 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=Bloomberg 数据同步完成,正在生成视图..., Progress=60% 2026-01-11 14:36:58,656 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在生成资产负债表..., Progress=65% 2026-01-11 14:37:00,022 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:37:00,222 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:37:01,201 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:37:02,336 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:37:02,336 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:37:02,337 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:37:03,150 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:37:22,024 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:37:22,035 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:37:22,566 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:37:22,566 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:37:23,111 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:37:24,952 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:37:27,495 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:37:27,497 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:37:28,899 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=资产负债表获取完成 (6行), Progress=70% 2026-01-11 14:37:30,140 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在生成现金流量表..., Progress=75% 2026-01-11 14:37:31,015 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:37:31,076 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:37:32,107 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:37:33,104 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:37:33,105 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:37:33,105 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:37:34,185 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:37:51,392 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:37:51,399 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:37:52,815 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:37:52,815 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:37:53,476 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:37:55,159 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:37:57,264 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:37:57,265 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:37:58,805 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=现金流量表获取完成 (6行), Progress=80% 2026-01-11 14:38:00,007 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在生成市场指标..., Progress=85% 2026-01-11 14:38:01,061 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:38:01,543 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:38:02,547 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:38:03,888 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:38:03,888 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:38:03,889 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:38:04,534 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:38:23,652 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:38:23,653 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:38:24,442 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:38:24,442 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:38:24,971 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:38:27,691 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:38:29,012 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:38:29,013 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:38:30,484 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=市场指标获取完成, Progress=90% 2026-01-11 14:38:31,595 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在获取分红数据..., Progress=87% 2026-01-11 14:38:32,315 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:38:32,603 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:38:33,597 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:38:34,575 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:38:34,575 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:38:34,576 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:38:35,248 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:38:54,723 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:38:54,724 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:38:55,410 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:38:55,410 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:38:56,350 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:39:01,031 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:39:05,447 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:39:05,448 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:39:07,601 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:39:07,661 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:39:08,705 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:39:10,856 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:39:10,856 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:39:10,856 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:39:11,769 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:39:33,605 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:39:33,607 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:39:34,183 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:39:34,183 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:39:35,123 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:39:36,722 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:39:37,396 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:39:37,396 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:39:38,584 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在获取回购数据..., Progress=90% 2026-01-11 14:39:44,103 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:39:44,166 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:39:45,279 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:39:47,917 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:39:47,923 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:39:47,923 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:39:48,876 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:40:09,105 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:40:09,108 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:40:10,071 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:40:10,071 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:40:10,705 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:40:12,293 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:40:13,368 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:40:13,368 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:40:14,361 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在获取员工数据..., Progress=93% 2026-01-11 14:40:14,916 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: APP US Equity 2026-01-11 14:40:14,977 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:40:16,037 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:40:17,021 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:40:17,021 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:40:17,021 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:40:18,635 - app.clients.bloomberg_client - INFO - ✅ Parsed 156 items from remote. 2026-01-11 14:40:42,412 - app.clients.bloomberg_client - INFO - ✅ Saved 156 records to database. 2026-01-11 14:40:42,413 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:40:43,424 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:40:43,424 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:40:44,012 - app.clients.bloomberg_client - INFO - ✅ Parsed 10 items from remote. 2026-01-11 14:40:47,867 - app.clients.bloomberg_client - INFO - ✅ Saved 10 records to database. 2026-01-11 14:40:48,962 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:40:48,963 - app.clients.bloomberg_client - INFO - ✅ Completed processing for APP US Equity 2026-01-11 14:40:49,624 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=正在处理统计信息..., Progress=96% 2026-01-11 14:40:50,686 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=31, Msg=数据获取完成, Progress=100% 2026-01-11 14:42:02,620 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果公司 2026-01-11 14:42:02,688 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 14:42:02,688 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 14:42:06,767 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 14:42:06,779 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.09秒, Tokens: prompt=165, completion=65, total=230 2026-01-11 14:42:06,780 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.16秒 2026-01-11 14:42:17,711 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 14:42:18,627 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 14:42:19,175 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 14:42:19,210 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 14:42:19,438 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 14:42:19,438 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=数据源连接成功, Progress=5% 2026-01-11 14:42:20,963 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在连接 Bloomberg 终端并同步所有数据(Basic, Currency, Price)..., Progress=10% 2026-01-11 14:42:21,645 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 14:42:21,919 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:42:22,888 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:42:23,797 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:42:23,798 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:42:23,798 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:42:24,535 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 14:42:50,707 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 14:42:50,716 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:42:51,483 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:42:51,485 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:42:52,126 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 14:42:55,226 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 14:42:56,276 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:42:56,277 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 14:42:57,035 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=Bloomberg 数据同步完成,正在生成视图..., Progress=60% 2026-01-11 14:42:58,402 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在生成资产负债表..., Progress=65% 2026-01-11 14:43:00,102 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=资产负债表获取完成 (10行), Progress=70% 2026-01-11 14:43:00,715 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在生成现金流量表..., Progress=75% 2026-01-11 14:43:01,893 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=现金流量表获取完成 (10行), Progress=80% 2026-01-11 14:43:02,235 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在生成市场指标..., Progress=85% 2026-01-11 14:43:04,877 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=市场指标获取完成, Progress=90% 2026-01-11 14:43:06,121 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在获取分红数据..., Progress=87% 2026-01-11 14:43:09,231 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在获取回购数据..., Progress=90% 2026-01-11 14:43:10,715 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在获取员工数据..., Progress=93% 2026-01-11 14:43:12,311 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=正在处理统计信息..., Progress=96% 2026-01-11 14:43:12,927 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=32, Msg=数据获取完成, Progress=100% 2026-01-11 14:45:28,629 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 14:45:29,646 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 14:45:30,071 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 14:45:30,114 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 14:45:30,324 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 14:45:30,324 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=数据源连接成功, Progress=5% 2026-01-11 14:45:30,847 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在连接 Bloomberg 终端并同步所有数据(Basic, Currency, Price)..., Progress=10% 2026-01-11 14:45:31,359 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 14:45:31,396 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 14:45:32,470 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 14:45:35,982 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 14:45:35,983 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 14:45:35,983 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 14:45:37,591 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 14:46:06,627 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 14:46:06,628 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 14:46:07,149 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 14:46:07,150 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 14:46:07,667 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 14:46:14,403 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 14:46:15,266 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 14:46:15,267 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 14:46:16,077 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=Bloomberg 数据同步完成,正在生成视图..., Progress=60% 2026-01-11 14:46:17,627 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在生成资产负债表..., Progress=65% 2026-01-11 14:46:18,348 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=资产负债表获取完成 (10行), Progress=70% 2026-01-11 14:46:19,802 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在生成现金流量表..., Progress=75% 2026-01-11 14:46:22,782 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=现金流量表获取完成 (10行), Progress=80% 2026-01-11 14:46:23,773 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在生成市场指标..., Progress=85% 2026-01-11 14:46:26,155 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=市场指标获取完成, Progress=90% 2026-01-11 14:46:27,039 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在获取分红数据..., Progress=87% 2026-01-11 14:46:30,344 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在获取回购数据..., Progress=90% 2026-01-11 14:46:32,322 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在获取员工数据..., Progress=93% 2026-01-11 14:46:34,459 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=正在处理统计信息..., Progress=96% 2026-01-11 14:46:35,283 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=33, Msg=数据获取完成, Progress=100% 2026-01-11 14:56:43,321 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果 2026-01-11 14:56:43,603 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 14:56:43,609 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 14:56:48,167 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 14:56:48,193 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.59秒, Tokens: prompt=164, completion=70, total=234 2026-01-11 14:56:48,194 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.87秒 2026-01-11 15:00:40,407 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果 2026-01-11 15:00:40,494 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 15:00:40,496 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 15:00:44,814 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 15:00:44,823 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.33秒, Tokens: prompt=164, completion=46, total=210 2026-01-11 15:00:44,823 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.42秒 2026-01-11 15:06:28,055 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果 2026-01-11 15:06:28,067 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 15:06:28,078 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 15:06:33,911 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 15:06:33,931 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 5.86秒, Tokens: prompt=164, completion=62, total=226 2026-01-11 15:06:33,931 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 5.87秒 2026-01-11 15:15:58,065 - app.services.data_fetcher_service - ERROR - Error fetching Bloomberg data from stockcard: cannot access local variable 'text' where it is not associated with a value Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/services/data_fetcher_service.py", line 483, in get_financial_data_from_db check_sql = text("SELECT 1 FROM stockcard WHERE Company_code = :code LIMIT 1") ^^^^ UnboundLocalError: cannot access local variable 'text' where it is not associated with a value 2026-01-11 15:17:56,819 - app.services.data_fetcher_service - ERROR - Error fetching Bloomberg data from stockcard: (sqlalchemy.dialects.postgresql.asyncpg.ProgrammingError) : column "period_end_date" does not exist [SQL: SELECT indicator, value, period_end_date, value_date FROM stockcard WHERE Company_code = $1 ] [parameters: ('AAPL US Equity',)] (Background on this error at: https://sqlalche.me/e/20/f405) Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 526, in _prepare_and_execute prepared_stmt, attributes = await adapt_connection._prepare( ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ operation, self._invalidate_schema_cache_asof ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 773, in _prepare prepared_stmt = await self._connection.prepare( ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ operation, name=self._prepared_statement_name_func() ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/asyncpg/connection.py", line 638, in prepare return await self._prepare( ^^^^^^^^^^^^^^^^^^^^ ...<4 lines>... ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/asyncpg/connection.py", line 657, in _prepare stmt = await self._get_statement( ^^^^^^^^^^^^^^^^^^^^^^^^^^ ...<5 lines>... ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/asyncpg/connection.py", line 443, in _get_statement statement = await self._protocol.prepare( ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ...<5 lines>... ) ^ File "asyncpg/protocol/protocol.pyx", line 165, in prepare asyncpg.exceptions.UndefinedColumnError: column "period_end_date" does not exist The above exception was the direct cause of the following exception: Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 1967, in _exec_single_context self.dialect.do_execute( ~~~~~~~~~~~~~~~~~~~~~~~^ cursor, str_statement, effective_parameters, context ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/default.py", line 952, in do_execute cursor.execute(statement, parameters) ~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 585, in execute self._adapt_connection.await_( ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ self._prepare_and_execute(operation, parameters) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/util/_concurrency_py3k.py", line 132, in await_only return current.parent.switch(awaitable) # type: ignore[no-any-return,attr-defined] # noqa: E501 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/util/_concurrency_py3k.py", line 196, in greenlet_spawn value = await result ^^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 563, in _prepare_and_execute self._handle_exception(error) ~~~~~~~~~~~~~~~~~~~~~~^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 513, in _handle_exception self._adapt_connection._handle_exception(error) ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 797, in _handle_exception raise translated_error from error sqlalchemy.dialects.postgresql.asyncpg.AsyncAdapt_asyncpg_dbapi.ProgrammingError: : column "period_end_date" does not exist The above exception was the direct cause of the following exception: Traceback (most recent call last): File "/Users/xucheng/git.qubit.ltd/FA3/backend/app/services/data_fetcher_service.py", line 506, in get_financial_data_from_db result = await db.execute(query, {"code": target_code}) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/ext/asyncio/session.py", line 449, in execute result = await greenlet_spawn( ^^^^^^^^^^^^^^^^^^^^^ ...<6 lines>... ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/util/_concurrency_py3k.py", line 201, in greenlet_spawn result = context.throw(*sys.exc_info()) File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/orm/session.py", line 2351, in execute return self._execute_internal( ~~~~~~~~~~~~~~~~~~~~~~^ statement, ^^^^^^^^^^ ...<4 lines>... _add_event=_add_event, ^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/orm/session.py", line 2258, in _execute_internal result = conn.execute( statement, params or {}, execution_options=execution_options ) File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 1419, in execute return meth( self, distilled_parameters, execution_options or NO_OPTIONS, ) File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/sql/elements.py", line 527, in _execute_on_connection return connection._execute_clauseelement( ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ self, distilled_params, execution_options ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 1641, in _execute_clauseelement ret = self._execute_context( dialect, ...<8 lines>... cache_hit=cache_hit, ) File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 1846, in _execute_context return self._exec_single_context( ~~~~~~~~~~~~~~~~~~~~~~~~~^ dialect, context, statement, parameters ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 1986, in _exec_single_context self._handle_dbapi_exception( ~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ e, str_statement, effective_parameters, cursor, context ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 2363, in _handle_dbapi_exception raise sqlalchemy_exception.with_traceback(exc_info[2]) from e File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/base.py", line 1967, in _exec_single_context self.dialect.do_execute( ~~~~~~~~~~~~~~~~~~~~~~~^ cursor, str_statement, effective_parameters, context ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/engine/default.py", line 952, in do_execute cursor.execute(statement, parameters) ~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 585, in execute self._adapt_connection.await_( ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ self._prepare_and_execute(operation, parameters) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ) ^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/util/_concurrency_py3k.py", line 132, in await_only return current.parent.switch(awaitable) # type: ignore[no-any-return,attr-defined] # noqa: E501 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/util/_concurrency_py3k.py", line 196, in greenlet_spawn value = await result ^^^^^^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 563, in _prepare_and_execute self._handle_exception(error) ~~~~~~~~~~~~~~~~~~~~~~^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 513, in _handle_exception self._adapt_connection._handle_exception(error) ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^ File "/Users/xucheng/git.qubit.ltd/FA3/.venv/lib/python3.13/site-packages/sqlalchemy/dialects/postgresql/asyncpg.py", line 797, in _handle_exception raise translated_error from error sqlalchemy.exc.ProgrammingError: (sqlalchemy.dialects.postgresql.asyncpg.ProgrammingError) : column "period_end_date" does not exist [SQL: SELECT indicator, value, period_end_date, value_date FROM stockcard WHERE Company_code = $1 ] [parameters: ('AAPL US Equity',)] (Background on this error at: https://sqlalche.me/e/20/f405) 2026-01-11 15:43:59,728 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=34, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 15:44:01,099 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=34, Msg=数据获取失败: expected an indented block after function definition on line 124 (bloomberg_fetcher.py, line 125), Progress=0% 2026-01-11 15:44:39,793 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 苹果 2026-01-11 15:44:39,874 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 15:44:39,875 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 15:44:44,181 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 15:44:44,189 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.32秒, Tokens: prompt=164, completion=63, total=227 2026-01-11 15:44:44,189 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.40秒 2026-01-11 15:59:11,029 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=35, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 15:59:12,862 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 15:59:13,130 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 15:59:13,159 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 15:59:13,404 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 15:59:13,404 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=35, Msg=数据源连接成功, Progress=10% 2026-01-11 15:59:16,017 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=35, Msg=正在连接 Bloomberg 终端并同步所有数据..., Progress=20% 2026-01-11 15:59:18,664 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 15:59:19,197 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 15:59:20,197 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 15:59:26,068 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 15:59:26,070 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 15:59:26,070 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 15:59:29,612 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 15:59:57,006 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 15:59:57,011 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 16:00:00,122 - app.clients.bloomberg_client - INFO - ✅ Parsed 378 items from remote. 2026-01-11 16:00:46,388 - app.clients.bloomberg_client - INFO - ✅ Saved 378 records to database. 2026-01-11 16:00:46,396 - app.clients.bloomberg_client - INFO - Fetching Price Data... 2026-01-11 16:00:47,361 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 16:00:49,667 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 16:00:52,371 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 16:00:52,372 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 16:00:52,374 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=35, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 17:49:08,337 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=36, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 17:49:11,579 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=36, Msg=数据获取失败: unexpected indent (bloomberg_client.py, line 742), Progress=0% 2026-01-11 17:49:31,857 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=37, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 17:49:32,874 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=37, Msg=数据获取失败: unexpected indent (bloomberg_client.py, line 742), Progress=0% 2026-01-11 17:52:55,229 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=38, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 17:52:57,114 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 17:52:57,377 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 17:52:57,567 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 17:52:57,627 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 17:52:57,627 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=38, Msg=数据源连接成功, Progress=10% 2026-01-11 17:52:58,668 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=38, Msg=正在连接 Bloomberg 终端并同步所有数据..., Progress=20% 2026-01-11 17:53:00,274 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 17:53:00,324 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 17:53:01,594 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 17:53:06,441 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 17:53:06,442 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 17:53:06,442 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 17:53:06,442 - app.clients.bloomberg_client - ERROR - Fetch failed for AAPL US Equity: Invalid format specifier ' company, "update_date": "2026-01-11", "currency": curr, "indicator": indicator_name, "value": val_str, "value_date": date_str ' for object of type 'str' 2026-01-11 17:53:06,443 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=38, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 17:56:04,443 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=39, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 17:56:06,275 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 17:56:06,974 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 17:56:07,498 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 17:56:09,407 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 17:56:09,407 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=39, Msg=数据源连接成功, Progress=10% 2026-01-11 17:56:11,858 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=39, Msg=正在连接 Bloomberg 终端并同步所有数据..., Progress=20% 2026-01-11 17:56:14,721 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 17:56:14,760 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 17:56:15,781 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 17:56:17,373 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 17:56:17,373 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 17:56:17,373 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 17:56:17,937 - app.clients.bloomberg_client - ERROR - ❌ Remote Execution Error: invalid syntax (2838341427.py, line 62) 2026-01-11 17:56:17,938 - app.clients.bloomberg_client - ERROR - Cell In[192], line 62  except Exception as e: ^ SyntaxError: invalid syntax 2026-01-11 17:56:17,954 - app.clients.bloomberg_client - ERROR - Fetch failed for AAPL US Equity: Remote Code Execution Failed: invalid syntax (2838341427.py, line 62) 2026-01-11 17:56:17,954 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=39, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 17:57:37,972 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=40, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 17:57:40,026 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 17:57:42,370 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 17:57:42,573 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 17:57:43,092 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 17:57:43,096 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=40, Msg=数据源连接成功, Progress=10% 2026-01-11 17:57:44,874 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=40, Msg=正在连接 Bloomberg 终端并同步所有数据..., Progress=20% 2026-01-11 17:57:46,326 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: AAPL US Equity 2026-01-11 17:57:46,397 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 17:57:47,318 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 17:57:49,396 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 17:57:49,397 - app.clients.bloomberg_client - INFO - Using currency: USD 2026-01-11 17:57:49,397 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 17:57:51,826 - app.clients.bloomberg_client - INFO - ✅ Parsed 220 items from remote. 2026-01-11 17:58:34,861 - app.clients.bloomberg_client - INFO - ✅ Saved 220 records to database. 2026-01-11 17:58:34,872 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 17:58:36,038 - app.clients.bloomberg_client - INFO - ✅ Parsed 378 items from remote. 2026-01-11 17:59:35,616 - app.clients.bloomberg_client - INFO - ✅ Saved 378 records to database. 2026-01-11 17:59:35,701 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 17:59:35,712 - app.clients.bloomberg_client - INFO - Found 10 revenue reporting dates. Fetching aligned price data... 2026-01-11 17:59:40,696 - app.clients.bloomberg_client - INFO - ✅ Parsed 20 items from remote. 2026-01-11 17:59:44,609 - app.clients.bloomberg_client - INFO - ✅ Saved 20 records to database. 2026-01-11 17:59:46,043 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 17:59:46,044 - app.clients.bloomberg_client - INFO - ✅ Completed processing for AAPL US Equity 2026-01-11 17:59:46,047 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=40, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 18:22:06,142 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 麒麟 2026-01-11 18:22:06,565 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 18:22:06,574 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 18:22:15,068 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 18:22:15,229 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 8.66秒, Tokens: prompt=165, completion=162, total=327 2026-01-11 18:22:15,231 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 3 个结果, 总耗时: 9.08秒 2026-01-11 18:22:23,454 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=41, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 18:22:25,534 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 18:22:27,266 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 18:22:27,310 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 18:22:27,375 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 18:22:27,376 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=41, Msg=数据源连接成功, Progress=10% 2026-01-11 18:22:29,955 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=41, Msg=正在连接 Bloomberg 终端并同步所有数据..., Progress=20% 2026-01-11 18:22:32,699 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-11 18:22:32,737 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 18:22:34,134 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 18:22:37,169 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 18:22:37,170 - app.clients.bloomberg_client - INFO - Using currency: JPY 2026-01-11 18:22:37,170 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 18:22:37,862 - app.clients.bloomberg_client - INFO - ✅ Parsed 215 items from remote. 2026-01-11 18:23:15,063 - app.clients.bloomberg_client - INFO - ✅ Saved 215 records to database. 2026-01-11 18:23:15,113 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 18:23:27,993 - app.clients.bloomberg_client - INFO - ✅ Parsed 260 items from remote. 2026-01-11 18:24:16,287 - app.clients.bloomberg_client - INFO - ✅ Saved 260 records to database. 2026-01-11 18:24:16,318 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 18:24:16,320 - app.clients.bloomberg_client - INFO - Found 9 revenue reporting dates. Fetching aligned price data... 2026-01-11 18:24:20,471 - app.clients.bloomberg_client - INFO - ✅ Parsed 27 items from remote. 2026-01-11 18:24:28,529 - app.clients.bloomberg_client - INFO - ✅ Saved 27 records to database. 2026-01-11 18:24:34,022 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 18:24:34,037 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-11 18:24:34,045 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=41, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 19:12:33,462 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 西贡啤酒 2026-01-11 19:12:33,722 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 19:12:33,737 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 19:12:40,170 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 19:12:40,201 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 6.48秒, Tokens: prompt=166, completion=77, total=243 2026-01-11 19:12:40,202 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 6.74秒 2026-01-11 19:12:48,354 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 19:12:50,232 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 19:12:50,649 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 19:12:50,679 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 19:12:50,740 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 19:12:50,740 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=数据源连接成功, Progress=10% 2026-01-11 19:12:51,527 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-11 19:12:52,476 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: SAB VN Equity 2026-01-11 19:12:52,478 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=Starting Bloomberg session..., Progress=20% 2026-01-11 19:12:53,429 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 19:12:53,430 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-11 19:12:55,239 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 19:12:57,415 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 19:12:57,416 - app.clients.bloomberg_client - INFO - Using currency: VND 2026-01-11 19:12:57,416 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 19:12:57,416 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=正在获取货币指标 (VND)..., Progress=41% 2026-01-11 19:12:59,610 - app.clients.bloomberg_client - INFO - ✅ Parsed 225 items from remote. 2026-01-11 19:13:24,646 - app.clients.bloomberg_client - INFO - ✅ Saved 225 records to database. 2026-01-11 19:13:24,653 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 19:13:24,653 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=正在获取非货币指标..., Progress=55% 2026-01-11 19:13:25,924 - app.clients.bloomberg_client - INFO - ✅ Parsed 249 items from remote. 2026-01-11 19:13:57,203 - app.clients.bloomberg_client - INFO - ✅ Saved 249 records to database. 2026-01-11 19:13:57,213 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 19:13:57,214 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=正在获取价格指标..., Progress=69% 2026-01-11 19:13:58,125 - app.clients.bloomberg_client - INFO - Found 9 revenue reporting dates. Fetching aligned price data... 2026-01-11 19:14:02,007 - app.clients.bloomberg_client - INFO - ✅ Parsed 27 items from remote. 2026-01-11 19:14:05,956 - app.clients.bloomberg_client - INFO - ✅ Saved 27 records to database. 2026-01-11 19:14:05,962 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=Finalizing data..., Progress=82% 2026-01-11 19:14:09,370 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 19:14:09,372 - app.clients.bloomberg_client - INFO - ✅ Completed processing for SAB VN Equity 2026-01-11 19:14:09,372 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=Bloomberg data sync complete, Progress=90% 2026-01-11 19:14:10,483 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=42, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 19:21:37,522 - app.main - INFO - 🔍 [搜索] 开始搜索股票: SAB 2026-01-11 19:21:37,544 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 19:21:37,561 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 19:21:47,453 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 19:21:47,481 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 9.94秒, Tokens: prompt=165, completion=243, total=408 2026-01-11 19:21:47,481 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 5 个结果, 总耗时: 9.95秒 2026-01-11 19:22:04,930 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 西贡啤酒 2026-01-11 19:22:04,931 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 19:22:04,931 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 19:22:08,982 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 19:22:08,987 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 4.06秒, Tokens: prompt=166, completion=83, total=249 2026-01-11 19:22:08,988 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 4.06秒 2026-01-11 19:53:39,156 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 19:53:42,089 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 19:53:43,025 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 19:53:43,284 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 19:53:43,706 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 19:53:43,707 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=数据源连接成功, Progress=10% 2026-01-11 19:53:44,492 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-11 19:53:45,349 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: SAB VN Equity 2026-01-11 19:53:45,349 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=Starting Bloomberg session..., Progress=20% 2026-01-11 19:53:47,085 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 19:53:47,085 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-11 19:53:49,516 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 19:53:50,682 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 19:53:50,683 - app.clients.bloomberg_client - INFO - Using currency: VND 2026-01-11 19:53:50,683 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 19:53:50,683 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=正在获取货币指标 (VND)..., Progress=41% 2026-01-11 19:53:52,442 - app.clients.bloomberg_client - INFO - ✅ Parsed 275 items from remote. 2026-01-11 19:54:24,667 - app.clients.bloomberg_client - INFO - ✅ Saved 275 records to database. 2026-01-11 19:54:24,669 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 19:54:24,669 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=正在获取非货币指标..., Progress=55% 2026-01-11 19:54:28,450 - app.clients.bloomberg_client - INFO - ✅ Parsed 290 items from remote. 2026-01-11 19:55:01,793 - app.clients.bloomberg_client - INFO - ✅ Saved 290 records to database. 2026-01-11 19:55:01,796 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 19:55:01,796 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=正在获取价格指标..., Progress=69% 2026-01-11 19:55:02,515 - app.clients.bloomberg_client - INFO - Found 11 revenue reporting dates. Fetching aligned price data... 2026-01-11 19:55:07,831 - app.clients.bloomberg_client - INFO - ✅ Parsed 27 items from remote. 2026-01-11 19:55:10,705 - app.clients.bloomberg_client - INFO - ✅ Saved 27 records to database. 2026-01-11 19:55:10,706 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=Finalizing data..., Progress=82% 2026-01-11 19:55:13,396 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 19:55:13,397 - app.clients.bloomberg_client - INFO - ✅ Completed processing for SAB VN Equity 2026-01-11 19:55:13,397 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=Bloomberg data sync complete, Progress=90% 2026-01-11 19:55:13,724 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=43, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 20:06:54,509 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 马山 2026-01-11 20:06:54,803 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash-exp 进行股票搜索 2026-01-11 20:06:54,810 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 20:07:00,658 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash-exp:generateContent "HTTP/1.1 200 OK" 2026-01-11 20:07:00,686 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 5.88秒, Tokens: prompt=164, completion=454, total=618 2026-01-11 20:07:00,686 - app.main - ERROR - ❌ [搜索] 搜索失败: Expecting value: line 1 column 1 (char 0), 耗时: 6.17秒 2026-01-11 20:07:12,799 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 迈瑞 2026-01-11 20:07:12,802 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash-exp 进行股票搜索 2026-01-11 20:07:12,803 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 20:07:16,206 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash-exp:generateContent "HTTP/1.1 200 OK" 2026-01-11 20:07:16,273 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 3.47秒, Tokens: prompt=164, completion=51, total=215 2026-01-11 20:07:16,273 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 3.47秒 2026-01-11 20:07:23,937 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=44, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 20:07:25,199 - app.services.data_fetcher_service - INFO - 📝 [数据获取] 股票代码格式化: 300760 -> 300760.SZ 2026-01-11 20:07:25,202 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=44, Msg=数据获取失败: Data source 'Tushare' not supported in backend., Progress=0% 2026-01-11 20:08:05,704 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 南微医学 2026-01-11 20:08:05,709 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.0-flash-exp 进行股票搜索 2026-01-11 20:08:05,714 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 20:08:08,410 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash-exp:generateContent "HTTP/1.1 200 OK" 2026-01-11 20:08:08,416 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 2.71秒, Tokens: prompt=165, completion=47, total=212 2026-01-11 20:08:08,417 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 1 个结果, 总耗时: 2.71秒 2026-01-11 20:12:35,247 - app.main - INFO - 🔍 [搜索] 开始搜索股票: 京东方 2026-01-11 20:12:35,259 - app.main - INFO - 🤖 [搜索-LLM] 调用 gemini-2.5-flash 进行股票搜索 2026-01-11 20:12:35,263 - google_genai.models - INFO - AFC is enabled with max remote calls: 10. 2026-01-11 20:12:41,922 - httpx - INFO - HTTP Request: POST https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent "HTTP/1.1 200 OK" 2026-01-11 20:12:41,940 - app.main - INFO - ✅ [搜索-LLM] 模型响应完成, 耗时: 6.68秒, Tokens: prompt=165, completion=118, total=283 2026-01-11 20:12:41,940 - app.main - INFO - ✅ [搜索] 搜索完成, 找到 2 个结果, 总耗时: 6.69秒 2026-01-11 20:12:46,388 - app.services.bloomberg_service - WARNING - No Bloomberg data found for symbol: 688029 2026-01-11 20:12:46,999 - app.services.bloomberg_service - WARNING - No Bloomberg data found for symbol: 688029 2026-01-11 20:12:49,015 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 20:12:49,938 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 20:12:50,218 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 20:12:50,255 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 20:12:50,478 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 20:12:50,478 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=数据源连接成功, Progress=10% 2026-01-11 20:12:51,598 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-11 20:12:53,887 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 000725 CN Equity 2026-01-11 20:12:53,888 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=Starting Bloomberg session..., Progress=20% 2026-01-11 20:12:54,806 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 20:12:54,824 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-11 20:12:57,924 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 20:12:59,486 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 20:12:59,487 - app.clients.bloomberg_client - INFO - Using currency: CNY 2026-01-11 20:12:59,487 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 20:12:59,487 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=正在获取货币指标 (CNY)..., Progress=41% 2026-01-11 20:13:00,726 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 20:13:00,726 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 20:13:00,726 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=正在获取非货币指标..., Progress=55% 2026-01-11 20:13:02,593 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 20:13:02,593 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 20:13:02,593 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=正在获取价格指标..., Progress=69% 2026-01-11 20:13:05,307 - app.clients.bloomberg_client - WARNING - No revenue dates found. Falling back to yearly price fetch. 2026-01-11 20:13:06,625 - app.clients.bloomberg_client - INFO - ✅ Parsed 1 items from remote. 2026-01-11 20:13:07,542 - app.clients.bloomberg_client - INFO - ✅ Saved 1 records to database. 2026-01-11 20:13:07,543 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=Finalizing data..., Progress=82% 2026-01-11 20:13:09,190 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 20:13:09,190 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 000725 CN Equity 2026-01-11 20:13:09,190 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=Bloomberg data sync complete, Progress=90% 2026-01-11 20:13:09,845 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=45, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 20:16:53,460 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 20:16:54,913 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 20:16:55,824 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 20:16:56,029 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 20:16:56,093 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 20:16:56,093 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=数据源连接成功, Progress=10% 2026-01-11 20:16:57,845 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-11 20:16:59,259 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 000725 CN Equity 2026-01-11 20:16:59,259 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=Starting Bloomberg session..., Progress=20% 2026-01-11 20:17:04,282 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 20:17:04,283 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-11 20:17:07,199 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 20:17:10,359 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 20:17:10,360 - app.clients.bloomberg_client - INFO - Using currency: CNY 2026-01-11 20:17:10,360 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 20:17:10,360 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=正在获取货币指标 (CNY)..., Progress=41% 2026-01-11 20:17:12,977 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 20:17:12,978 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 20:17:12,978 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=正在获取非货币指标..., Progress=55% 2026-01-11 20:17:14,860 - app.clients.bloomberg_client - INFO - ✅ Parsed 0 items from remote. 2026-01-11 20:17:14,860 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 20:17:14,860 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=正在获取价格指标..., Progress=69% 2026-01-11 20:17:15,741 - app.clients.bloomberg_client - WARNING - No revenue dates found. Falling back to yearly price fetch. 2026-01-11 20:17:16,420 - app.clients.bloomberg_client - INFO - ✅ Parsed 1 items from remote. 2026-01-11 20:17:18,827 - app.clients.bloomberg_client - INFO - ✅ Saved 1 records to database. 2026-01-11 20:17:18,828 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=Finalizing data..., Progress=82% 2026-01-11 20:17:20,848 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 20:17:20,849 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 000725 CN Equity 2026-01-11 20:17:20,849 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=Bloomberg data sync complete, Progress=90% 2026-01-11 20:17:21,552 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=46, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 20:28:14,645 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 20:28:15,567 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 20:28:16,647 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 20:28:16,682 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 20:28:16,751 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 20:28:16,751 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=数据源连接成功, Progress=10% 2026-01-11 20:28:17,601 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-11 20:28:18,043 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 000725 CH Equity 2026-01-11 20:28:18,044 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=Starting Bloomberg session..., Progress=20% 2026-01-11 20:28:20,154 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 20:28:20,155 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-11 20:28:22,319 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 20:28:24,083 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 20:28:24,083 - app.clients.bloomberg_client - INFO - Using currency: CNY 2026-01-11 20:28:24,083 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 20:28:24,083 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=正在获取货币指标 (CNY)..., Progress=41% 2026-01-11 20:28:26,200 - app.clients.bloomberg_client - INFO - ✅ Parsed 350 items from remote. 2026-01-11 20:29:11,923 - app.clients.bloomberg_client - INFO - ✅ Saved 350 records to database. 2026-01-11 20:29:11,931 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 20:29:11,931 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=正在获取非货币指标..., Progress=55% 2026-01-11 20:30:20,069 - app.clients.bloomberg_client - ERROR - Error receiving WS message: Connection timed out 2026-01-11 20:30:20,070 - app.clients.bloomberg_client - WARNING - ⚠️ No JSON output found in remote response. 2026-01-11 20:30:20,070 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 20:30:20,070 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=正在获取价格指标..., Progress=69% 2026-01-11 20:30:21,168 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-11 20:30:31,156 - app.clients.bloomberg_client - INFO - ✅ Parsed 381 items from remote. 2026-01-11 20:31:23,214 - app.clients.bloomberg_client - INFO - ✅ Saved 381 records to database. 2026-01-11 20:31:23,222 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=Finalizing data..., Progress=82% 2026-01-11 20:31:27,141 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 20:31:27,143 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 000725 CH Equity 2026-01-11 20:31:27,143 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=Bloomberg data sync complete, Progress=90% 2026-01-11 20:31:28,046 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=47, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-11 21:26:47,212 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=48, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 21:26:48,858 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=48, Msg=数据获取失败: invalid syntax (bloomberg_client.py, line 456), Progress=0% 2026-01-11 21:29:14,203 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=正在初始化数据获取..., Progress=0% 2026-01-11 21:29:15,499 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-11 21:29:17,316 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-11 21:29:17,347 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-11 21:29:17,849 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-11 21:29:17,849 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=数据源连接成功, Progress=10% 2026-01-11 21:29:18,166 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-11 21:29:19,192 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-11 21:29:19,192 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=Starting Bloomberg session..., Progress=20% 2026-01-11 21:29:19,532 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-11 21:29:19,532 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-11 21:29:23,309 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-11 21:29:24,098 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-11 21:29:24,098 - app.clients.bloomberg_client - INFO - Using currency: JPY 2026-01-11 21:29:24,098 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-11 21:29:24,099 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=正在获取货币指标 (JPY)..., Progress=41% 2026-01-11 21:29:29,127 - app.clients.bloomberg_client - INFO - ✅ Parsed 331 items from remote. 2026-01-11 21:30:02,714 - app.clients.bloomberg_client - INFO - ✅ Saved 331 records to database. 2026-01-11 21:30:02,723 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-11 21:30:02,723 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=正在获取非货币指标..., Progress=55% 2026-01-11 21:30:03,912 - app.clients.bloomberg_client - INFO - ✅ Parsed 382 items from remote. 2026-01-11 21:30:40,420 - app.clients.bloomberg_client - INFO - ✅ Saved 382 records to database. 2026-01-11 21:30:40,427 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-11 21:30:40,427 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=正在获取价格指标..., Progress=69% 2026-01-11 21:30:42,051 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-11 21:30:48,054 - app.clients.bloomberg_client - INFO - ✅ Parsed 42 items from remote. 2026-01-11 21:30:57,003 - app.clients.bloomberg_client - INFO - ✅ Saved 42 records to database. 2026-01-11 21:30:57,006 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=Finalizing data..., Progress=82% 2026-01-11 21:30:59,001 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-11 21:30:59,004 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-11 21:30:59,004 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=Bloomberg data sync complete, Progress=90% 2026-01-11 21:30:59,770 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=49, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-12 08:38:48,085 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=正在初始化数据获取..., Progress=0% 2026-01-12 08:38:48,574 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-12 08:38:48,811 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-12 08:38:48,841 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-12 08:38:48,892 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-12 08:38:48,892 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=数据源连接成功, Progress=10% 2026-01-12 08:38:49,179 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-12 08:38:49,424 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-12 08:38:49,424 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=Starting Bloomberg session..., Progress=20% 2026-01-12 08:38:49,723 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-12 08:38:49,723 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-12 08:38:51,005 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-12 08:38:51,593 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-12 08:38:51,594 - app.clients.bloomberg_client - INFO - Using auto-detected currency: JPY 2026-01-12 08:38:51,594 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-12 08:38:51,594 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=正在获取货币指标 (JPY)..., Progress=41% 2026-01-12 08:38:52,587 - app.clients.bloomberg_client - INFO - ✅ Parsed 331 items from remote. 2026-01-12 08:39:02,351 - app.clients.bloomberg_client - INFO - ✅ Saved 331 records to database. 2026-01-12 08:39:02,354 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-12 08:39:02,354 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=正在获取非货币指标..., Progress=55% 2026-01-12 08:39:03,417 - app.clients.bloomberg_client - INFO - ✅ Parsed 382 items from remote. 2026-01-12 08:39:14,223 - app.clients.bloomberg_client - INFO - ✅ Saved 382 records to database. 2026-01-12 08:39:14,224 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-12 08:39:14,225 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=正在获取价格指标..., Progress=69% 2026-01-12 08:39:14,707 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-12 08:39:20,704 - app.clients.bloomberg_client - INFO - ✅ Parsed 42 items from remote. 2026-01-12 08:39:22,410 - app.clients.bloomberg_client - INFO - ✅ Saved 42 records to database. 2026-01-12 08:39:22,411 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=Finalizing data..., Progress=82% 2026-01-12 08:39:22,999 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-12 08:39:23,000 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-12 08:39:23,000 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=Bloomberg data sync complete, Progress=90% 2026-01-12 08:39:23,269 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=50, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-12 08:39:31,217 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=正在初始化数据获取..., Progress=0% 2026-01-12 08:39:31,485 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-12 08:39:31,706 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-12 08:39:31,733 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-12 08:39:31,785 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-12 08:39:31,786 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=数据源连接成功, Progress=10% 2026-01-12 08:39:32,035 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-12 08:39:32,286 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-12 08:39:32,286 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=Starting Bloomberg session..., Progress=20% 2026-01-12 08:39:32,593 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-12 08:39:32,593 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-12 08:39:33,771 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-12 08:39:34,217 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-12 08:39:34,218 - app.clients.bloomberg_client - INFO - Using auto-detected currency: JPY 2026-01-12 08:39:34,218 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-12 08:39:34,218 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=正在获取货币指标 (JPY)..., Progress=41% 2026-01-12 08:39:35,121 - app.clients.bloomberg_client - INFO - ✅ Parsed 331 items from remote. 2026-01-12 08:39:44,689 - app.clients.bloomberg_client - INFO - ✅ Saved 331 records to database. 2026-01-12 08:39:44,690 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-12 08:39:44,691 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=正在获取非货币指标..., Progress=55% 2026-01-12 08:39:45,574 - app.clients.bloomberg_client - INFO - ✅ Parsed 382 items from remote. 2026-01-12 08:39:55,843 - app.clients.bloomberg_client - INFO - ✅ Saved 382 records to database. 2026-01-12 08:39:55,845 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-12 08:39:55,845 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=正在获取价格指标..., Progress=69% 2026-01-12 08:39:56,105 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-12 08:40:02,124 - app.clients.bloomberg_client - INFO - ✅ Parsed 42 items from remote. 2026-01-12 08:40:03,440 - app.clients.bloomberg_client - INFO - ✅ Saved 42 records to database. 2026-01-12 08:40:03,441 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=Finalizing data..., Progress=82% 2026-01-12 08:40:04,197 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-12 08:40:04,197 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-12 08:40:04,197 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=Bloomberg data sync complete, Progress=90% 2026-01-12 08:40:04,447 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=51, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-12 08:40:18,684 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=正在初始化数据获取..., Progress=0% 2026-01-12 08:40:18,940 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-12 08:40:19,174 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-12 08:40:19,206 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-12 08:40:19,405 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-12 08:40:19,406 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=数据源连接成功, Progress=10% 2026-01-12 08:40:19,653 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-12 08:40:19,900 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-12 08:40:19,901 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=Starting Bloomberg session..., Progress=20% 2026-01-12 08:40:20,212 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-12 08:40:20,212 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-12 08:40:21,392 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-12 08:40:21,956 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-12 08:40:21,956 - app.clients.bloomberg_client - INFO - Using auto-detected currency: JPY 2026-01-12 08:40:21,956 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-12 08:40:21,957 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=正在获取货币指标 (JPY)..., Progress=41% 2026-01-12 08:40:22,751 - app.clients.bloomberg_client - INFO - ✅ Parsed 331 items from remote. 2026-01-12 08:40:33,054 - app.clients.bloomberg_client - INFO - ✅ Saved 331 records to database. 2026-01-12 08:40:33,056 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-12 08:40:33,057 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=正在获取非货币指标..., Progress=55% 2026-01-12 08:40:34,013 - app.clients.bloomberg_client - INFO - ✅ Parsed 382 items from remote. 2026-01-12 08:40:45,644 - app.clients.bloomberg_client - INFO - ✅ Saved 382 records to database. 2026-01-12 08:40:45,647 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-12 08:40:45,647 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=正在获取价格指标..., Progress=69% 2026-01-12 08:40:45,903 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-12 08:40:51,580 - app.clients.bloomberg_client - INFO - ✅ Parsed 42 items from remote. 2026-01-12 08:40:53,077 - app.clients.bloomberg_client - INFO - ✅ Saved 42 records to database. 2026-01-12 08:40:53,092 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=Finalizing data..., Progress=82% 2026-01-12 08:40:53,882 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-12 08:40:53,883 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-12 08:40:53,883 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=Bloomberg data sync complete, Progress=90% 2026-01-12 08:40:54,126 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=52, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-12 08:43:24,711 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=正在初始化数据获取..., Progress=0% 2026-01-12 08:43:25,139 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-12 08:43:25,365 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-12 08:43:25,393 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-12 08:43:25,442 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-12 08:43:25,442 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=数据源连接成功, Progress=10% 2026-01-12 08:43:25,702 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-12 08:43:25,971 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-12 08:43:25,971 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=Starting Bloomberg session..., Progress=20% 2026-01-12 08:43:26,469 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-12 08:43:26,469 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-12 08:43:27,652 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-12 08:43:28,341 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-12 08:43:28,342 - app.clients.bloomberg_client - INFO - Using forced currency: USD 2026-01-12 08:43:28,342 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-12 08:43:28,342 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=正在获取货币指标 (USD)..., Progress=41% 2026-01-12 08:43:29,720 - app.clients.bloomberg_client - INFO - ✅ Parsed 331 items from remote. 2026-01-12 08:43:39,230 - app.clients.bloomberg_client - INFO - ✅ Saved 331 records to database. 2026-01-12 08:43:39,232 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-12 08:43:39,232 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=正在获取非货币指标..., Progress=55% 2026-01-12 08:43:40,229 - app.clients.bloomberg_client - INFO - ✅ Parsed 382 items from remote. 2026-01-12 08:43:50,591 - app.clients.bloomberg_client - INFO - ✅ Saved 382 records to database. 2026-01-12 08:43:50,593 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-12 08:43:50,593 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=正在获取价格指标..., Progress=69% 2026-01-12 08:43:50,851 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-12 08:43:56,659 - app.clients.bloomberg_client - INFO - ✅ Parsed 42 items from remote. 2026-01-12 08:43:58,108 - app.clients.bloomberg_client - INFO - ✅ Saved 42 records to database. 2026-01-12 08:43:58,109 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=Finalizing data..., Progress=82% 2026-01-12 08:43:58,702 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-12 08:43:58,703 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-12 08:43:58,703 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=Bloomberg data sync complete, Progress=90% 2026-01-12 08:43:58,998 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=53, Msg=Bloomberg 数据同步完成, Progress=100% 2026-01-12 09:30:47,629 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=正在初始化数据获取..., Progress=0% 2026-01-12 09:30:48,117 - app.clients.bloomberg_client - INFO - Connecting to Jupyter at http://192.168.3.161:8888... 2026-01-12 09:30:48,341 - app.clients.bloomberg_client - INFO - ✅ Authentication successful. 2026-01-12 09:30:48,532 - app.clients.bloomberg_client - INFO - ✅ Found existing kernel: bc27f3b1-b028-434a-99fa-c1cad4495a87 (remote_env) 2026-01-12 09:30:48,587 - app.clients.bloomberg_client - INFO - ✅ WebSocket connected. 2026-01-12 09:30:48,588 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=数据源连接成功, Progress=10% 2026-01-12 09:30:48,836 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=正在连接 Bloomberg 终端..., Progress=20% 2026-01-12 09:30:49,112 - app.clients.bloomberg_client - INFO - 🚀 Starting fetch for: 2503 JP Equity 2026-01-12 09:30:49,112 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=Starting Bloomberg session..., Progress=20% 2026-01-12 09:30:49,445 - app.clients.bloomberg_client - INFO - Fetching Basic Data... 2026-01-12 09:30:49,445 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=Fetching Company Basic Info..., Progress=27% 2026-01-12 09:30:50,731 - app.clients.bloomberg_client - INFO - ✅ Parsed 2 items from remote. 2026-01-12 09:30:51,108 - app.clients.bloomberg_client - INFO - ✅ Saved 2 records to database. 2026-01-12 09:30:51,109 - app.clients.bloomberg_client - INFO - Using forced currency: CNY 2026-01-12 09:30:51,109 - app.clients.bloomberg_client - INFO - Fetching Currency Data... 2026-01-12 09:30:51,109 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=正在获取货币指标 (CNY)..., Progress=41% 2026-01-12 09:30:52,131 - app.clients.bloomberg_client - INFO - ✅ Parsed 331 items from remote. 2026-01-12 09:31:03,562 - app.clients.bloomberg_client - INFO - ✅ Saved 331 records to database. 2026-01-12 09:31:03,563 - app.clients.bloomberg_client - INFO - Fetching Non-Currency Data... 2026-01-12 09:31:03,564 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=正在获取非货币指标..., Progress=55% 2026-01-12 09:31:04,637 - app.clients.bloomberg_client - INFO - ✅ Parsed 382 items from remote. 2026-01-12 09:31:16,853 - app.clients.bloomberg_client - INFO - ✅ Saved 382 records to database. 2026-01-12 09:31:16,854 - app.clients.bloomberg_client - INFO - Fetching Price Data (Aligned)... 2026-01-12 09:31:16,855 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=正在获取价格指标..., Progress=69% 2026-01-12 09:31:17,130 - app.clients.bloomberg_client - INFO - Found 14 revenue reporting dates. Fetching aligned price data... 2026-01-12 09:31:23,659 - app.clients.bloomberg_client - INFO - ✅ Parsed 42 items from remote. 2026-01-12 09:31:25,896 - app.clients.bloomberg_client - INFO - ✅ Saved 42 records to database. 2026-01-12 09:31:25,896 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=Finalizing data..., Progress=82% 2026-01-12 09:31:26,487 - app.clients.bloomberg_client - INFO - ✅ Cleanup and View Refresh completed. 2026-01-12 09:31:26,489 - app.clients.bloomberg_client - INFO - ✅ Completed processing for 2503 JP Equity 2026-01-12 09:31:26,490 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=Bloomberg data sync complete, Progress=90% 2026-01-12 09:31:26,791 - app.services.data_fetcher_service - INFO - 🔄 [进度更新] ID=54, Msg=Bloomberg 数据同步完成, Progress=100%