Files
MoFin/venv/lib/python3.12/site-packages/akshare/fund/fund_position_lg.py
T
知微 fa45d8aa5f fix: 小果地址统一node122(兼容LAN+EasyTier)
- health_checklist.json: 192.168.1.122→node122
- ocr_client.py: docstring IP→node122
- docs/market-data-requirements.md: IP→node122
- 所有API调用通过ProxyHandler({})绕过系统代理
  Privoxy对node122:18003返回500,直连正常
2026-06-30 02:56:35 +08:00

136 lines
3.8 KiB
Python

#!/usr/bin/env python
# -*- coding:utf-8 -*-
"""
Date: 2023/4/5 22:05
Desc: 乐咕乐股-基金仓位
https://legulegu.com/stockdata/fund-position/pos-stock
"""
import pandas as pd
import requests
from akshare.stock_feature.stock_a_indicator import get_token_lg, get_cookie_csrf
def fund_stock_position_lg() -> pd.DataFrame:
"""
乐咕乐股-基金仓位-股票型基金仓位
https://legulegu.com/stockdata/fund-position/pos-stock
:return: 股票型基金仓位
:rtype: pandas.DataFrame
"""
url = "https://legulegu.com/api/stockdata/fund-position"
token = get_token_lg()
params = {
"token": token,
"type": "pos_stock",
"category": "总仓位",
"marketId": "5",
}
r = requests.get(
url,
params=params,
**get_cookie_csrf(url="https://legulegu.com/stockdata/fund-position/pos-stock"),
)
data_json = r.json()
temp_df = pd.DataFrame(data_json)
temp_df["date"] = pd.to_datetime(temp_df["date"]).dt.date
temp_df = temp_df[
[
"date",
"close",
"position",
]
]
temp_df["date"] = pd.to_datetime(temp_df["date"]).dt.date
temp_df["close"] = pd.to_numeric(temp_df["close"], errors="coerce")
temp_df["position"] = pd.to_numeric(temp_df["position"], errors="coerce")
return temp_df
def fund_balance_position_lg() -> pd.DataFrame:
"""
乐咕乐股-基金仓位-平衡混合型基金仓位
https://legulegu.com/stockdata/fund-position/pos-pingheng
:return: 平衡混合型基金仓位
:rtype: pandas.DataFrame
"""
url = "https://legulegu.com/api/stockdata/fund-position"
token = get_token_lg()
params = {
"token": token,
"type": "pos_pingheng",
"category": "总仓位",
"marketId": "5",
}
r = requests.get(
url,
params=params,
**get_cookie_csrf(
url="https://legulegu.com/stockdata/fund-position/pos-pingheng"
),
)
data_json = r.json()
temp_df = pd.DataFrame(data_json)
temp_df["date"] = pd.to_datetime(temp_df["date"]).dt.date
temp_df = temp_df[
[
"date",
"close",
"position",
]
]
temp_df["date"] = pd.to_datetime(temp_df["date"]).dt.date
temp_df["close"] = pd.to_numeric(temp_df["close"], errors="coerce")
temp_df["position"] = pd.to_numeric(temp_df["position"], errors="coerce")
return temp_df
def fund_linghuo_position_lg() -> pd.DataFrame:
"""
乐咕乐股-基金仓位-灵活配置型基金仓位
https://legulegu.com/stockdata/fund-position/pos-linghuo
:return: 灵活配置型基金仓位
:rtype: pandas.DataFrame
"""
url = "https://legulegu.com/api/stockdata/fund-position"
token = get_token_lg()
params = {
"token": token,
"type": "pos_linghuo",
"category": "总仓位",
"marketId": "5",
}
r = requests.get(
url,
params=params,
**get_cookie_csrf(
url="https://legulegu.com/stockdata/fund-position/pos-linghuo"
),
)
data_json = r.json()
temp_df = pd.DataFrame(data_json)
temp_df["date"] = pd.to_datetime(temp_df["date"]).dt.date
temp_df = temp_df[
[
"date",
"close",
"position",
]
]
temp_df["date"] = pd.to_datetime(temp_df["date"]).dt.date
temp_df["close"] = pd.to_numeric(temp_df["close"], errors="coerce")
temp_df["position"] = pd.to_numeric(temp_df["position"], errors="coerce")
return temp_df
if __name__ == "__main__":
fund_stock_position_lg_df = fund_stock_position_lg()
print(fund_stock_position_lg_df)
fund_balance_position_lg_df = fund_balance_position_lg()
print(fund_balance_position_lg_df)
fund_linghuo_position_lg_df = fund_linghuo_position_lg()
print(fund_linghuo_position_lg_df)