持仓导入完成:holding.xls→SQLite+portfolio.json全同步
1. 从 ~/stocks/holding.xls 导入25只持仓(14A/11H) 2. 同时写入 portfolio.json + SQLite holdings 表 3. stale_push_wlin 现金来源从 stale_report 改为 portfolio.json 4. portfolio.json 增加 total_assets 字段兼容 stale_detector 5. 导入脚本已规范化为 MoFin/scripts/import_holding_xls.py 用法:python3 import_holding_xls.py [--cash 金额] 6. 全量策略重评+决策树重建立即执行 Dad下次更新holding.xls后跑: cd MoFin && python3 scripts/import_holding_xls.py
This commit is contained in:
+47
-39
@@ -5,21 +5,22 @@
|
||||
"name": "德明利",
|
||||
"shares": 100,
|
||||
"avail_shares": 100,
|
||||
"price": 790.0,
|
||||
"price": 790.9,
|
||||
"cost_price": 737.0374,
|
||||
"pl": 5096.26,
|
||||
"pl_pct": 6.91,
|
||||
"currency": "CNY",
|
||||
"market_val": 78800.0,
|
||||
"cost_amount": 73703.74,
|
||||
"exchange_rate": 0.866
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": 4.75
|
||||
},
|
||||
{
|
||||
"code": "01478",
|
||||
"name": "丘钛科技",
|
||||
"shares": 11000,
|
||||
"avail_shares": 11000,
|
||||
"price": 7.57,
|
||||
"price": 7.54,
|
||||
"cost_price": 13.8089,
|
||||
"pl": -59438.6,
|
||||
"pl_pct": -45.18,
|
||||
@@ -27,14 +28,14 @@
|
||||
"market_val": 72120.15,
|
||||
"cost_amount": 131558.75,
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": -3.93
|
||||
"change_pct": -4.19
|
||||
},
|
||||
{
|
||||
"code": "600739",
|
||||
"name": "辽宁成大",
|
||||
"shares": 6600,
|
||||
"avail_shares": 6600,
|
||||
"price": 10.44,
|
||||
"price": 10.45,
|
||||
"cost_price": 12.2862,
|
||||
"pl": -11789.02,
|
||||
"pl_pct": -14.54,
|
||||
@@ -42,14 +43,14 @@
|
||||
"market_val": 69300.0,
|
||||
"cost_amount": 81089.02,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -1.97
|
||||
"change_pct": -1.88
|
||||
},
|
||||
{
|
||||
"code": "601899",
|
||||
"name": "紫金矿业",
|
||||
"shares": 2400,
|
||||
"avail_shares": 2400,
|
||||
"price": 27.38,
|
||||
"price": 27.36,
|
||||
"cost_price": 40.2685,
|
||||
"pl": -30572.29,
|
||||
"pl_pct": -31.63,
|
||||
@@ -63,21 +64,22 @@
|
||||
"name": "华恒生物",
|
||||
"shares": 2800,
|
||||
"avail_shares": 0,
|
||||
"price": 21.31,
|
||||
"price": 21.35,
|
||||
"cost_price": 21.5085,
|
||||
"pl": -135.75,
|
||||
"pl_pct": -0.23,
|
||||
"currency": "CNY",
|
||||
"market_val": 60088.0,
|
||||
"cost_amount": 60223.75,
|
||||
"exchange_rate": 0.866
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -2.2
|
||||
},
|
||||
{
|
||||
"code": "09988",
|
||||
"name": "阿里巴巴-W",
|
||||
"shares": 700,
|
||||
"avail_shares": 700,
|
||||
"price": 98.55,
|
||||
"price": 98.6,
|
||||
"cost_price": 126.1516,
|
||||
"pl": -16582.48,
|
||||
"pl_pct": -21.68,
|
||||
@@ -85,7 +87,7 @@
|
||||
"market_val": 59899.48,
|
||||
"cost_amount": 76481.96,
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": -0.4
|
||||
"change_pct": -0.35
|
||||
},
|
||||
{
|
||||
"code": "603259",
|
||||
@@ -106,7 +108,7 @@
|
||||
"name": "中芯国际",
|
||||
"shares": 300,
|
||||
"avail_shares": 300,
|
||||
"price": 149.89,
|
||||
"price": 150.64,
|
||||
"cost_price": 126.0681,
|
||||
"pl": 7173.58,
|
||||
"pl_pct": 18.97,
|
||||
@@ -114,7 +116,7 @@
|
||||
"market_val": 44994.0,
|
||||
"cost_amount": 37820.42,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": 5.78
|
||||
"change_pct": 6.31
|
||||
},
|
||||
{
|
||||
"code": "01888",
|
||||
@@ -150,7 +152,7 @@
|
||||
"name": "中银香港",
|
||||
"shares": 1000,
|
||||
"avail_shares": 1000,
|
||||
"price": 46.22,
|
||||
"price": 46.26,
|
||||
"cost_price": 43.7892,
|
||||
"pl": 2053.39,
|
||||
"pl_pct": 5.41,
|
||||
@@ -158,14 +160,14 @@
|
||||
"market_val": 39979.18,
|
||||
"cost_amount": 37925.79,
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": -1.66
|
||||
"change_pct": -1.62
|
||||
},
|
||||
{
|
||||
"code": "300750",
|
||||
"name": "宁德时代",
|
||||
"shares": 100,
|
||||
"avail_shares": 100,
|
||||
"price": 391.09,
|
||||
"price": 391.19,
|
||||
"cost_price": 401.7803,
|
||||
"pl": -1063.03,
|
||||
"pl_pct": -2.65,
|
||||
@@ -173,21 +175,22 @@
|
||||
"market_val": 39115.0,
|
||||
"cost_amount": 40178.03,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -0.36
|
||||
"change_pct": -0.34
|
||||
},
|
||||
{
|
||||
"code": "01211",
|
||||
"name": "比亚迪股份",
|
||||
"shares": 600,
|
||||
"avail_shares": 600,
|
||||
"price": 75.0,
|
||||
"price": 74.85,
|
||||
"cost_price": 105.0542,
|
||||
"pl": -15539.97,
|
||||
"pl_pct": -28.47,
|
||||
"currency": "HKD",
|
||||
"market_val": 39052.45,
|
||||
"cost_amount": 54592.42,
|
||||
"exchange_rate": 0.8661
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": -1.25
|
||||
},
|
||||
{
|
||||
"code": "00700",
|
||||
@@ -209,7 +212,7 @@
|
||||
"name": "中芯国际",
|
||||
"shares": 500,
|
||||
"avail_shares": 500,
|
||||
"price": 83.15,
|
||||
"price": 83.25,
|
||||
"cost_price": 76.0724,
|
||||
"pl": 3151.55,
|
||||
"pl_pct": 9.57,
|
||||
@@ -217,28 +220,29 @@
|
||||
"market_val": 36094.72,
|
||||
"cost_amount": 32943.17,
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": 6.81
|
||||
"change_pct": 6.62
|
||||
},
|
||||
{
|
||||
"code": "09868",
|
||||
"name": "小鹏集团-W",
|
||||
"shares": 700,
|
||||
"avail_shares": 700,
|
||||
"price": 50.2,
|
||||
"price": 50.1,
|
||||
"cost_price": 51.3644,
|
||||
"pl": -675.62,
|
||||
"pl_pct": -2.17,
|
||||
"currency": "HKD",
|
||||
"market_val": 30465.07,
|
||||
"cost_amount": 31140.69,
|
||||
"exchange_rate": 0.8661
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": 1.5
|
||||
},
|
||||
{
|
||||
"code": "600036",
|
||||
"name": "招商银行",
|
||||
"shares": 800,
|
||||
"avail_shares": 800,
|
||||
"price": 37.06,
|
||||
"price": 37.05,
|
||||
"cost_price": 38.1582,
|
||||
"pl": -846.53,
|
||||
"pl_pct": -2.77,
|
||||
@@ -246,14 +250,14 @@
|
||||
"market_val": 29680.0,
|
||||
"cost_amount": 30526.53,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -0.91
|
||||
"change_pct": -0.94
|
||||
},
|
||||
{
|
||||
"code": "300548",
|
||||
"name": "长芯博创",
|
||||
"shares": 100,
|
||||
"avail_shares": 100,
|
||||
"price": 276.12,
|
||||
"price": 276.79,
|
||||
"cost_price": 231.46,
|
||||
"pl": 4766.0,
|
||||
"pl_pct": 20.59,
|
||||
@@ -261,14 +265,14 @@
|
||||
"market_val": 27912.0,
|
||||
"cost_amount": 23146.0,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -3.46
|
||||
"change_pct": -3.23
|
||||
},
|
||||
{
|
||||
"code": "02318",
|
||||
"name": "中国平安",
|
||||
"shares": 500,
|
||||
"avail_shares": 500,
|
||||
"price": 52.7,
|
||||
"price": 52.8,
|
||||
"cost_price": 54.8199,
|
||||
"pl": -896.35,
|
||||
"pl_pct": -3.78,
|
||||
@@ -276,7 +280,7 @@
|
||||
"market_val": 22843.39,
|
||||
"cost_amount": 23739.74,
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": -1.68
|
||||
"change_pct": -1.49
|
||||
},
|
||||
{
|
||||
"code": "300035",
|
||||
@@ -290,14 +294,15 @@
|
||||
"currency": "CNY",
|
||||
"market_val": 22442.0,
|
||||
"cost_amount": 31207.91,
|
||||
"exchange_rate": 0.866
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -2.08
|
||||
},
|
||||
{
|
||||
"code": "000700",
|
||||
"name": "模塑科技",
|
||||
"shares": 1400,
|
||||
"avail_shares": 1400,
|
||||
"price": 14.53,
|
||||
"price": 14.52,
|
||||
"cost_price": 14.8336,
|
||||
"pl": -327.0,
|
||||
"pl_pct": -1.57,
|
||||
@@ -305,14 +310,14 @@
|
||||
"market_val": 20440.0,
|
||||
"cost_amount": 20767.0,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -3.0
|
||||
"change_pct": -3.07
|
||||
},
|
||||
{
|
||||
"code": "518880",
|
||||
"name": "黄金ETF华安",
|
||||
"shares": 2400,
|
||||
"avail_shares": 2400,
|
||||
"price": 8.43,
|
||||
"price": 8.44,
|
||||
"cost_price": 12.1915,
|
||||
"pl": -8982.04,
|
||||
"pl_pct": -30.7,
|
||||
@@ -320,21 +325,22 @@
|
||||
"market_val": 20277.6,
|
||||
"cost_amount": 29259.64,
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -1.21
|
||||
"change_pct": -1.16
|
||||
},
|
||||
{
|
||||
"code": "01088",
|
||||
"name": "中国神华",
|
||||
"shares": 500,
|
||||
"avail_shares": 500,
|
||||
"price": 41.92,
|
||||
"price": 41.84,
|
||||
"cost_price": 45.974,
|
||||
"pl": -1764.27,
|
||||
"pl_pct": -8.86,
|
||||
"currency": "HKD",
|
||||
"market_val": 18144.8,
|
||||
"cost_amount": 19909.06,
|
||||
"exchange_rate": 0.8661
|
||||
"exchange_rate": 0.8661,
|
||||
"change_pct": -0.52
|
||||
},
|
||||
{
|
||||
"code": "600563",
|
||||
@@ -355,14 +361,15 @@
|
||||
"name": "双一科技",
|
||||
"shares": 400,
|
||||
"avail_shares": 400,
|
||||
"price": 22.7,
|
||||
"price": 22.68,
|
||||
"cost_price": 27.178,
|
||||
"pl": -1759.2,
|
||||
"pl_pct": -16.18,
|
||||
"currency": "CNY",
|
||||
"market_val": 9112.0,
|
||||
"cost_amount": 10871.2,
|
||||
"exchange_rate": 0.866
|
||||
"exchange_rate": 0.866,
|
||||
"change_pct": -3.98
|
||||
}
|
||||
],
|
||||
"cash": 80476,
|
||||
@@ -370,5 +377,6 @@
|
||||
"total_pl": -164810.3,
|
||||
"position_pct": 92.0,
|
||||
"updated_at": "2026-06-24 11:47",
|
||||
"source": "/home/hmo/stocks/holding.xls"
|
||||
"source": "/home/hmo/stocks/holding.xls",
|
||||
"total_assets": 1010675.93
|
||||
}
|
||||
Reference in New Issue
Block a user