akshare 1.14.49__py3-none-any.whl → 1.17.99__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (343) hide show
  1. akshare/__init__.py +595 -129
  2. akshare/air/air_hebei.py +77 -54
  3. akshare/air/air_zhenqi.py +0 -4
  4. akshare/air/cons.py +1 -0
  5. akshare/air/crypto.js +1 -1
  6. akshare/air/outcrypto.js +1 -1
  7. akshare/article/cons.py +1 -0
  8. akshare/article/epu_index.py +4 -3
  9. akshare/article/ff_factor.py +19 -8
  10. akshare/article/fred_md.py +4 -1
  11. akshare/article/risk_rv.py +3 -8
  12. akshare/bank/bank_cbirc_2020.py +11 -11
  13. akshare/bank/cons.py +7 -6
  14. akshare/bond/bond_buy_back_em.py +228 -0
  15. akshare/bond/bond_cb_sina.py +1 -0
  16. akshare/bond/bond_cb_ths.py +17 -9
  17. akshare/bond/bond_cbond.py +19 -14
  18. akshare/bond/bond_china.py +38 -39
  19. akshare/bond/bond_china_money.py +1 -1
  20. akshare/bond/bond_convert.py +10 -9
  21. akshare/bond/bond_em.py +37 -17
  22. akshare/bond/bond_summary.py +38 -37
  23. akshare/bond/bond_zh_cov.py +31 -40
  24. akshare/bond/bond_zh_sina.py +4 -0
  25. akshare/bond/cons.py +14 -11
  26. akshare/cal/__init__.py +0 -0
  27. akshare/cal/rv.py +170 -0
  28. akshare/cost/cost_living.py +7 -5
  29. akshare/crypto/__init__.py +1 -1
  30. akshare/crypto/crypto_bitcoin_cme.py +9 -7
  31. akshare/crypto/crypto_hold.py +4 -2
  32. akshare/currency/currency.py +1 -0
  33. akshare/currency/currency_china_bank_sina.py +11 -6
  34. akshare/data/__init__.py +1 -1
  35. akshare/data/cninfo.js +1 -1
  36. akshare/datasets.py +10 -21
  37. akshare/economic/cons.py +10 -3
  38. akshare/economic/macro_australia.py +74 -69
  39. akshare/economic/macro_bank.py +95 -653
  40. akshare/economic/macro_canada.py +92 -81
  41. akshare/economic/macro_china.py +97 -105
  42. akshare/economic/macro_china_hk.py +0 -1
  43. akshare/economic/macro_euro.py +103 -56
  44. akshare/economic/macro_finance_ths.py +7 -5
  45. akshare/economic/macro_germany.py +1 -1
  46. akshare/economic/macro_japan.py +0 -1
  47. akshare/economic/macro_other.py +1 -6
  48. akshare/economic/macro_swiss.py +2 -3
  49. akshare/economic/macro_uk.py +1 -1
  50. akshare/economic/macro_usa.py +7 -9
  51. akshare/economic/marco_cnbs.py +11 -6
  52. akshare/energy/energy_carbon.py +0 -1
  53. akshare/energy/energy_oil_em.py +1 -2
  54. akshare/event/cons.py +1 -0
  55. akshare/exceptions.py +43 -0
  56. akshare/file_fold/calendar.json +245 -2
  57. akshare/forex/__init__.py +0 -0
  58. akshare/forex/cons.py +192 -0
  59. akshare/forex/forex_em.py +149 -0
  60. akshare/fortune/fortune_500.py +1 -37
  61. akshare/fortune/fortune_bloomberg.py +6 -3
  62. akshare/fortune/fortune_forbes_500.py +3 -6
  63. akshare/fortune/fortune_hurun.py +2 -1
  64. akshare/fortune/fortune_xincaifu_500.py +17 -14
  65. akshare/fund/fund_announcement_em.py +145 -0
  66. akshare/fund/fund_aum_em.py +49 -35
  67. akshare/fund/fund_em.py +251 -220
  68. akshare/fund/fund_etf_em.py +44 -35
  69. akshare/fund/fund_etf_sina.py +75 -27
  70. akshare/fund/fund_etf_ths.py +2 -0
  71. akshare/fund/fund_fee_em.py +172 -0
  72. akshare/fund/fund_fhsp_em.py +42 -32
  73. akshare/fund/fund_init_em.py +8 -5
  74. akshare/fund/fund_lof_em.py +12 -19
  75. akshare/fund/fund_manager.py +25 -11
  76. akshare/fund/fund_overview_em.py +42 -0
  77. akshare/fund/fund_portfolio_em.py +23 -21
  78. akshare/fund/fund_position_lg.py +19 -8
  79. akshare/fund/fund_rank_em.py +2 -5
  80. akshare/fund/fund_rating.py +33 -12
  81. akshare/fund/fund_scale_em.py +24 -13
  82. akshare/fund/fund_scale_sina.py +20 -10
  83. akshare/fund/fund_xq.py +3 -2
  84. akshare/futures/cons.py +135 -39
  85. akshare/futures/cot.py +55 -56
  86. akshare/futures/futures_basis.py +49 -11
  87. akshare/futures/futures_comex_em.py +1 -0
  88. akshare/futures/futures_comm_ctp.py +1 -1
  89. akshare/futures/futures_contract_detail.py +59 -9
  90. akshare/futures/futures_daily_bar.py +66 -59
  91. akshare/futures/futures_foreign.py +14 -8
  92. akshare/futures/futures_hf_em.py +215 -61
  93. akshare/futures/futures_hist_em.py +191 -0
  94. akshare/futures/futures_hq_sina.py +5 -3
  95. akshare/futures/futures_index_ccidx.py +24 -82
  96. akshare/futures/futures_inventory_99.py +70 -272
  97. akshare/futures/futures_inventory_em.py +14 -11
  98. akshare/futures/futures_news_shmet.py +2 -2
  99. akshare/futures/futures_roll_yield.py +11 -24
  100. akshare/futures/futures_rule.py +7 -3
  101. akshare/futures/futures_rule_em.py +38 -0
  102. akshare/futures/futures_settlement_price_sgx.py +21 -6
  103. akshare/futures/futures_stock_js.py +0 -1
  104. akshare/futures/futures_to_spot.py +5 -6
  105. akshare/futures/futures_warehouse_receipt.py +48 -47
  106. akshare/futures/futures_zh_sina.py +3 -3
  107. akshare/futures/receipt.py +298 -165
  108. akshare/futures/requests_fun.py +16 -3
  109. akshare/futures/symbol_var.py +32 -13
  110. akshare/futures_derivative/cons.py +100 -103
  111. akshare/futures_derivative/futures_contract_info_cffex.py +55 -39
  112. akshare/futures_derivative/futures_contract_info_czce.py +2 -0
  113. akshare/futures_derivative/futures_contract_info_dce.py +43 -17
  114. akshare/futures_derivative/futures_contract_info_gfex.py +43 -31
  115. akshare/futures_derivative/futures_contract_info_ine.py +43 -34
  116. akshare/futures_derivative/futures_contract_info_shfe.py +3 -4
  117. akshare/futures_derivative/futures_cot_sina.py +8 -6
  118. akshare/futures_derivative/futures_index_sina.py +25 -13
  119. akshare/fx/cons.py +12 -7
  120. akshare/fx/fx_c_swap_cm.py +62 -0
  121. akshare/fx/fx_quote.py +3 -2
  122. akshare/fx/fx_quote_baidu.py +2 -1
  123. akshare/hf/__init__.py +1 -1
  124. akshare/hf/hf_sp500.py +8 -7
  125. akshare/index/cons.py +132 -28
  126. akshare/index/index_cni.py +7 -7
  127. akshare/index/index_cons.py +2 -2
  128. akshare/index/index_csindex.py +68 -0
  129. akshare/index/index_cx.py +20 -20
  130. akshare/index/index_drewry.py +17 -16
  131. akshare/index/index_eri.py +1 -0
  132. akshare/index/index_global_em.py +167 -0
  133. akshare/index/index_global_sina.py +82 -0
  134. akshare/index/index_kq_fz.py +17 -14
  135. akshare/index/index_kq_ss.py +1 -0
  136. akshare/index/index_option_qvix.py +351 -16
  137. akshare/index/index_research_sw.py +21 -21
  138. akshare/index/index_spot.py +9 -5
  139. akshare/index/index_stock_hk.py +5 -9
  140. akshare/index/index_stock_zh.py +111 -24
  141. akshare/index/index_stock_zh_csindex.py +3 -367
  142. akshare/index/index_sugar.py +18 -4
  143. akshare/index/index_sw.py +10 -2
  144. akshare/index/index_yw.py +53 -75
  145. akshare/index/index_zh_em.py +15 -82
  146. akshare/interest_rate/interbank_rate_em.py +0 -1
  147. akshare/movie/jm.js +0 -1
  148. akshare/news/__init__.py +1 -1
  149. akshare/news/news_baidu.py +395 -222
  150. akshare/news/news_stock.py +49 -16
  151. akshare/option/cons.py +2 -2
  152. akshare/option/option_commodity.py +341 -220
  153. akshare/option/option_commodity_sina.py +22 -26
  154. akshare/option/option_contract_info_ctp.py +63 -0
  155. akshare/option/option_current_sse.py +61 -0
  156. akshare/option/option_current_szse.py +84 -0
  157. akshare/option/option_czce.py +37 -9
  158. akshare/option/option_daily_stats_sse_szse.py +0 -1
  159. akshare/option/option_em.py +4 -8
  160. akshare/option/option_finance.py +60 -12
  161. akshare/option/option_finance_sina.py +7 -7
  162. akshare/option/option_lhb_em.py +0 -1
  163. akshare/option/option_margin.py +62 -0
  164. akshare/option/option_premium_analysis_em.py +58 -53
  165. akshare/option/option_risk_analysis_em.py +11 -8
  166. akshare/option/option_risk_indicator_sse.py +3 -4
  167. akshare/option/option_value_analysis_em.py +62 -55
  168. akshare/other/__init__.py +1 -1
  169. akshare/pro/__init__.py +0 -1
  170. akshare/pro/client.py +6 -4
  171. akshare/pro/cons.py +3 -2
  172. akshare/pro/data_pro.py +6 -5
  173. akshare/qdii/__init__.py +0 -0
  174. akshare/qdii/qdii_jsl.py +233 -0
  175. akshare/qhkc/__init__.py +1 -6
  176. akshare/qhkc/qhkc_api.py +64 -22
  177. akshare/qhkc_web/__init__.py +1 -6
  178. akshare/qhkc_web/qhkc_fund.py +10 -6
  179. akshare/qhkc_web/qhkc_index.py +28 -14
  180. akshare/qhkc_web/qhkc_tool.py +62 -59
  181. akshare/rate/__init__.py +1 -1
  182. akshare/rate/repo_rate.py +36 -32
  183. akshare/reits/__init__.py +1 -1
  184. akshare/reits/reits_basic.py +149 -13
  185. akshare/request.py +117 -0
  186. akshare/spot/__init__.py +1 -1
  187. akshare/spot/spot_hog_soozhu.py +165 -3
  188. akshare/spot/spot_sge.py +70 -9
  189. akshare/stock/cons.py +60 -23
  190. akshare/stock/stock_allotment_cninfo.py +8 -8
  191. akshare/stock/stock_ask_bid_em.py +3 -78
  192. akshare/stock/stock_board_concept_em.py +160 -35
  193. akshare/stock/stock_board_industry_em.py +163 -70
  194. akshare/stock/stock_dividend_cninfo.py +31 -17
  195. akshare/stock/stock_dzjy_em.py +347 -260
  196. akshare/stock/stock_fund_em.py +72 -64
  197. akshare/stock/stock_fund_hold.py +1 -2
  198. akshare/stock/stock_gsrl_em.py +1 -0
  199. akshare/stock/stock_hk_comparison_em.py +175 -0
  200. akshare/stock/stock_hk_famous.py +4 -5
  201. akshare/stock/stock_hk_fhpx_ths.py +2 -1
  202. akshare/stock/stock_hk_hot_rank_em.py +1 -0
  203. akshare/stock/stock_hk_sina.py +84 -36
  204. akshare/stock/stock_hold_control_cninfo.py +82 -0
  205. akshare/stock/stock_hold_control_em.py +0 -2
  206. akshare/stock/stock_hot_rank_em.py +4 -1
  207. akshare/stock/stock_hot_search_baidu.py +32 -19
  208. akshare/stock/stock_hot_up_em.py +4 -1
  209. akshare/stock/stock_hsgt_em.py +155 -0
  210. akshare/stock/stock_industry.py +1 -0
  211. akshare/stock/stock_industry_cninfo.py +1 -2
  212. akshare/stock/stock_info.py +6 -4
  213. akshare/stock/stock_info_em.py +17 -11
  214. akshare/stock/stock_intraday_em.py +4 -78
  215. akshare/stock/stock_intraday_sina.py +2 -2
  216. akshare/stock/stock_news_cx.py +39 -0
  217. akshare/stock/stock_profile_cninfo.py +7 -7
  218. akshare/stock/stock_profile_em.py +302 -0
  219. akshare/stock/stock_rank_forecast.py +6 -5
  220. akshare/stock/stock_repurchase_em.py +7 -2
  221. akshare/stock/stock_share_changes_cninfo.py +7 -5
  222. akshare/stock/stock_share_hold.py +24 -20
  223. akshare/stock/stock_stop.py +6 -6
  224. akshare/stock/stock_summary.py +153 -417
  225. akshare/stock/stock_us_famous.py +5 -6
  226. akshare/stock/stock_us_js.py +3 -2
  227. akshare/stock/stock_us_pink.py +38 -27
  228. akshare/stock/stock_us_sina.py +7 -3
  229. akshare/stock/stock_weibo_nlp.py +18 -20
  230. akshare/stock/stock_xq.py +24 -22
  231. akshare/stock/stock_zh_a_sina.py +8 -5
  232. akshare/stock/stock_zh_a_special.py +240 -243
  233. akshare/stock/stock_zh_a_tick_tx.py +11 -3
  234. akshare/stock/stock_zh_ah_tx.py +23 -26
  235. akshare/stock/stock_zh_b_sina.py +2 -2
  236. akshare/stock/stock_zh_comparison_em.py +250 -0
  237. akshare/stock/stock_zh_kcb_sina.py +67 -64
  238. akshare/stock_a/__init__.py +0 -0
  239. akshare/stock_a/stock_board_concept_name_em.py +170 -0
  240. akshare/stock_a/stock_individual_fund_flow_rank.py +258 -0
  241. akshare/stock_a/stock_zh_a_spot.py +212 -0
  242. akshare/stock_feature/cons.py +1 -0
  243. akshare/stock_feature/stock_a_indicator.py +9 -54
  244. akshare/stock_feature/stock_a_pe_and_pb.py +23 -5
  245. akshare/stock_feature/stock_account_em.py +0 -1
  246. akshare/stock_feature/stock_all_pb.py +2 -1
  247. akshare/stock_feature/stock_analyst_em.py +36 -30
  248. akshare/stock_feature/stock_board_concept_ths.py +328 -0
  249. akshare/stock_feature/stock_board_industry_ths.py +57 -2
  250. akshare/stock_feature/stock_buffett_index_lg.py +10 -8
  251. akshare/stock_feature/stock_classify_sina.py +3 -6
  252. akshare/stock_feature/stock_comment_em.py +81 -144
  253. akshare/stock_feature/stock_congestion_lg.py +2 -1
  254. akshare/stock_feature/stock_cyq_em.py +5 -11
  255. akshare/stock_feature/stock_disclosure_cninfo.py +6 -6
  256. akshare/stock_feature/stock_dxsyl_em.py +121 -74
  257. akshare/stock_feature/stock_ebs_lg.py +5 -4
  258. akshare/stock_feature/stock_esg_sina.py +29 -7
  259. akshare/stock_feature/stock_fhps_em.py +2 -1
  260. akshare/stock_feature/stock_fhps_ths.py +15 -7
  261. akshare/stock_feature/stock_fund_flow.py +30 -22
  262. akshare/stock_feature/stock_gddh_em.py +19 -11
  263. akshare/stock_feature/stock_gdfx_em.py +226 -113
  264. akshare/stock_feature/stock_gdhs.py +75 -50
  265. akshare/stock_feature/stock_gdzjc_em.py +21 -10
  266. akshare/stock_feature/stock_gpzy_em.py +78 -46
  267. akshare/stock_feature/stock_gxl_lg.py +3 -2
  268. akshare/stock_feature/stock_hist_em.py +137 -234
  269. akshare/stock_feature/stock_hist_tx.py +13 -10
  270. akshare/stock_feature/stock_hk_valuation_baidu.py +20 -8
  271. akshare/stock_feature/stock_hot_xq.py +4 -6
  272. akshare/stock_feature/stock_hsgt_em.py +269 -97
  273. akshare/stock_feature/stock_hsgt_exchange_rate.py +115 -87
  274. akshare/stock_feature/stock_hsgt_min_em.py +13 -16
  275. akshare/stock_feature/stock_info.py +7 -80
  276. akshare/stock_feature/stock_inner_trade_xq.py +38 -31
  277. akshare/stock_feature/stock_jgdy_em.py +43 -40
  278. akshare/stock_feature/stock_lhb_em.py +119 -3
  279. akshare/stock_feature/stock_margin_em.py +0 -1
  280. akshare/stock_feature/stock_margin_sse.py +0 -2
  281. akshare/stock_feature/stock_pankou_em.py +71 -35
  282. akshare/stock_feature/stock_qsjy_em.py +13 -4
  283. akshare/stock_feature/stock_report_em.py +151 -7
  284. akshare/stock_feature/stock_research_report_em.py +55 -20
  285. akshare/stock_feature/stock_sy_em.py +20 -15
  286. akshare/stock_feature/stock_technology_ths.py +122 -77
  287. akshare/stock_feature/stock_tfp_em.py +2 -1
  288. akshare/stock_feature/stock_three_report_em.py +21 -5
  289. akshare/stock_feature/stock_ttm_lyr.py +18 -9
  290. akshare/stock_feature/stock_value_em.py +83 -0
  291. akshare/stock_feature/stock_yjbb_em.py +58 -32
  292. akshare/stock_feature/stock_yjyg_cninfo.py +6 -2
  293. akshare/stock_feature/stock_yjyg_em.py +1 -1
  294. akshare/stock_feature/stock_yzxdr_em.py +24 -22
  295. akshare/stock_feature/stock_zdhtmx_em.py +20 -6
  296. akshare/stock_feature/stock_zh_vote_baidu.py +4 -1
  297. akshare/stock_feature/stock_ztb_em.py +39 -24
  298. akshare/stock_fundamental/__init__.py +1 -1
  299. akshare/stock_fundamental/stock_basic_info_xq.py +119 -0
  300. akshare/stock_fundamental/{stock_finance_hk.py → stock_finance_hk_em.py} +23 -16
  301. akshare/stock_fundamental/{stock_finance.py → stock_finance_sina.py} +60 -7
  302. akshare/stock_fundamental/stock_finance_ths.py +524 -57
  303. akshare/stock_fundamental/stock_finance_us_em.py +268 -0
  304. akshare/stock_fundamental/stock_gbjg_em.py +80 -0
  305. akshare/stock_fundamental/stock_hold.py +26 -17
  306. akshare/stock_fundamental/stock_ipo_declare.py +1 -0
  307. akshare/stock_fundamental/stock_kcb_detail_sse.py +10 -10
  308. akshare/stock_fundamental/stock_kcb_sse.py +26 -25
  309. akshare/stock_fundamental/stock_notice.py +12 -3
  310. akshare/stock_fundamental/stock_profit_forecast_em.py +31 -13
  311. akshare/stock_fundamental/stock_profit_forecast_hk_etnet.py +64 -41
  312. akshare/stock_fundamental/stock_profit_forecast_ths.py +86 -35
  313. akshare/stock_fundamental/stock_recommend.py +20 -4
  314. akshare/stock_fundamental/stock_zygc.py +5 -62
  315. akshare/utils/context.py +43 -0
  316. akshare/utils/demjson.py +2009 -1338
  317. akshare/utils/func.py +49 -2
  318. akshare/utils/multi_decrypt.py +53 -0
  319. akshare/utils/token_process.py +6 -5
  320. {akshare-1.14.49.dist-info → akshare-1.17.99.dist-info}/METADATA +54 -80
  321. akshare-1.17.99.dist-info/RECORD +409 -0
  322. {akshare-1.14.49.dist-info → akshare-1.17.99.dist-info}/WHEEL +1 -1
  323. {akshare-1.14.49.dist-info → akshare-1.17.99.dist-info/licenses}/LICENSE +1 -1
  324. tests/test_func.py +3 -5
  325. akshare/bond/bond_futures.py +0 -50
  326. akshare/bond/bond_investing.py +0 -139
  327. akshare/crypto/crypto_hist_investing.py +0 -249
  328. akshare/fund/fund_announcement.py +0 -56
  329. akshare/futures/futures_international.py +0 -170
  330. akshare/futures/futures_news_baidu.py +0 -54
  331. akshare/futures/inventory_data.py +0 -100
  332. akshare/futures_derivative/futures_index_price_nh.py +0 -61
  333. akshare/futures_derivative/futures_index_return_nh.py +0 -47
  334. akshare/futures_derivative/futures_index_volatility_nh.py +0 -53
  335. akshare/futures_derivative/futures_other_index_nh.py +0 -145
  336. akshare/index/index_fear_greed_funddb.py +0 -78
  337. akshare/index/index_investing.py +0 -232
  338. akshare/sport/__init__.py +0 -6
  339. akshare/sport/sport_olympic.py +0 -27
  340. akshare/stock_feature/stock_wencai.py +0 -104
  341. akshare/stock_fundamental/stock_mda_ym.py +0 -40
  342. akshare-1.14.49.dist-info/RECORD +0 -387
  343. {akshare-1.14.49.dist-info → akshare-1.17.99.dist-info}/top_level.txt +0 -0
@@ -1,7 +1,7 @@
1
1
  # -*- coding:utf-8 -*-
2
2
  # !/usr/bin/env python
3
3
  """
4
- Date: 2024/7/31 16:30
4
+ Date: 2024/8/10 15:30
5
5
  Desc: 搜猪-生猪大数据-各省均价实时排行榜
6
6
  https://www.soozhu.com/price/data/center/
7
7
  """
@@ -16,7 +16,7 @@ def spot_hog_soozhu() -> pd.DataFrame:
16
16
  搜猪-生猪大数据-各省均价实时排行榜
17
17
  https://www.soozhu.com/price/data/center/
18
18
  :return: 各省均价实时排行榜
19
- :rtype: pd.DataFrame
19
+ :rtype: pandas.DataFrame
20
20
  """
21
21
  session = requests.session()
22
22
  url = "https://www.soozhu.com/price/data/center/"
@@ -43,7 +43,7 @@ def spot_hog_year_trend_soozhu() -> pd.DataFrame:
43
43
  搜猪-生猪大数据-今年以来全国出栏均价走势
44
44
  https://www.soozhu.com/price/data/center/
45
45
  :return: 今年以来全国出栏均价走势
46
- :rtype: pd.DataFrame
46
+ :rtype: pandas.DataFrame
47
47
  """
48
48
  session = requests.session()
49
49
  url = "https://www.soozhu.com/price/data/center/"
@@ -62,9 +62,171 @@ def spot_hog_year_trend_soozhu() -> pd.DataFrame:
62
62
  return temp_df
63
63
 
64
64
 
65
+ def spot_hog_lean_price_soozhu() -> pd.DataFrame:
66
+ """
67
+ 搜猪-生猪大数据-全国瘦肉型肉猪
68
+ https://www.soozhu.com/price/data/center/
69
+ :return: 全国瘦肉型肉猪
70
+ :rtype: pandas.DataFrame
71
+ """
72
+ session = requests.session()
73
+ url = "https://www.soozhu.com/price/data/center/"
74
+ r = session.get(url)
75
+ soup = BeautifulSoup(r.text, features="lxml")
76
+ token = soup.find(name="input", attrs={"name": "csrfmiddlewaretoken"})["value"]
77
+ url = "https://www.soozhu.com/price/data/center/"
78
+ payload = {"act": "pricetrend", "indid": "", "csrfmiddlewaretoken": token}
79
+ r = session.post(url, data=payload)
80
+ data_json = r.json()
81
+ temp_df = pd.DataFrame(data_json["datalist"])
82
+ temp_df.columns = ["日期", "价格"]
83
+ temp_df["日期"] = pd.to_datetime(temp_df["日期"], errors="coerce").dt.date
84
+ temp_df["价格"] = pd.to_numeric(temp_df["价格"], errors="coerce")
85
+ temp_df.sort_values(by=["日期"], ignore_index=True, inplace=True)
86
+ return temp_df
87
+
88
+
89
+ def spot_hog_three_way_soozhu() -> pd.DataFrame:
90
+ """
91
+ 搜猪-生猪大数据-全国三元仔猪
92
+ https://www.soozhu.com/price/data/center/
93
+ :return: 全国三元仔猪
94
+ :rtype: pandas.DataFrame
95
+ """
96
+ session = requests.session()
97
+ url = "https://www.soozhu.com/price/data/center/"
98
+ r = session.get(url)
99
+ soup = BeautifulSoup(r.text, features="lxml")
100
+ token = soup.find(name="input", attrs={"name": "csrfmiddlewaretoken"})["value"]
101
+ url = "https://www.soozhu.com/price/data/center/"
102
+ payload = {"act": "pricetrend", "indid": "4", "csrfmiddlewaretoken": token}
103
+ r = session.post(url, data=payload)
104
+ data_json = r.json()
105
+ temp_df = pd.DataFrame(data_json["datalist"])
106
+ temp_df.columns = ["日期", "价格"]
107
+ temp_df["日期"] = pd.to_datetime(temp_df["日期"], errors="coerce").dt.date
108
+ temp_df["价格"] = pd.to_numeric(temp_df["价格"], errors="coerce")
109
+ temp_df.sort_values(by=["日期"], ignore_index=True, inplace=True)
110
+ return temp_df
111
+
112
+
113
+ def spot_hog_crossbred_soozhu() -> pd.DataFrame:
114
+ """
115
+ 搜猪-生猪大数据-全国后备二元母猪
116
+ https://www.soozhu.com/price/data/center/
117
+ :return: 全国后备二元母猪
118
+ :rtype: pandas.DataFrame
119
+ """
120
+ session = requests.session()
121
+ url = "https://www.soozhu.com/price/data/center/"
122
+ r = session.get(url)
123
+ soup = BeautifulSoup(r.text, features="lxml")
124
+ token = soup.find(name="input", attrs={"name": "csrfmiddlewaretoken"})["value"]
125
+ url = "https://www.soozhu.com/price/data/center/"
126
+ payload = {"act": "pricetrend", "indid": "6", "csrfmiddlewaretoken": token}
127
+ r = session.post(url, data=payload)
128
+ data_json = r.json()
129
+ temp_df = pd.DataFrame(data_json["datalist"])
130
+ temp_df.columns = ["日期", "价格"]
131
+ temp_df["日期"] = pd.to_datetime(temp_df["日期"], errors="coerce").dt.date
132
+ temp_df["价格"] = pd.to_numeric(temp_df["价格"], errors="coerce")
133
+ temp_df.sort_values(by=["日期"], ignore_index=True, inplace=True)
134
+ return temp_df
135
+
136
+
137
+ def spot_corn_price_soozhu() -> pd.DataFrame:
138
+ """
139
+ 搜猪-生猪大数据-全国玉米价格走势
140
+ https://www.soozhu.com/price/data/center/
141
+ :return: 全国玉米价格走势
142
+ :rtype: pandas.DataFrame
143
+ """
144
+ session = requests.session()
145
+ url = "https://www.soozhu.com/price/data/center/"
146
+ r = session.get(url)
147
+ soup = BeautifulSoup(r.text, features="lxml")
148
+ token = soup.find(name="input", attrs={"name": "csrfmiddlewaretoken"})["value"]
149
+ url = "https://www.soozhu.com/price/data/center/"
150
+ payload = {"act": "pricetrend", "indid": "8", "csrfmiddlewaretoken": token}
151
+ r = session.post(url, data=payload)
152
+ data_json = r.json()
153
+ temp_df = pd.DataFrame(data_json["datalist"])
154
+ temp_df.columns = ["日期", "价格"]
155
+ temp_df["日期"] = pd.to_datetime(temp_df["日期"], errors="coerce").dt.date
156
+ temp_df["价格"] = pd.to_numeric(temp_df["价格"], errors="coerce")
157
+ temp_df.sort_values(by=["日期"], ignore_index=True, inplace=True)
158
+ return temp_df
159
+
160
+
161
+ def spot_soybean_price_soozhu() -> pd.DataFrame:
162
+ """
163
+ 搜猪-生猪大数据-全国豆粕价格走势
164
+ https://www.soozhu.com/price/data/center/
165
+ :return: 全国豆粕价格走势
166
+ :rtype: pandas.DataFrame
167
+ """
168
+ session = requests.session()
169
+ url = "https://www.soozhu.com/price/data/center/"
170
+ r = session.get(url)
171
+ soup = BeautifulSoup(r.text, features="lxml")
172
+ token = soup.find(name="input", attrs={"name": "csrfmiddlewaretoken"})["value"]
173
+ url = "https://www.soozhu.com/price/data/center/"
174
+ payload = {"act": "pricetrend", "indid": "9", "csrfmiddlewaretoken": token}
175
+ r = session.post(url, data=payload)
176
+ data_json = r.json()
177
+ temp_df = pd.DataFrame(data_json["datalist"])
178
+ temp_df.columns = ["日期", "价格"]
179
+ temp_df["日期"] = pd.to_datetime(temp_df["日期"], errors="coerce").dt.date
180
+ temp_df["价格"] = pd.to_numeric(temp_df["价格"], errors="coerce")
181
+ temp_df.sort_values(by=["日期"], ignore_index=True, inplace=True)
182
+ return temp_df
183
+
184
+
185
+ def spot_mixed_feed_soozhu() -> pd.DataFrame:
186
+ """
187
+ 搜猪-生猪大数据-全国育肥猪合料(含自配料)半月走势
188
+ https://www.soozhu.com/price/data/center/
189
+ :return: 全国育肥猪合料(含自配料)半月走势
190
+ :rtype: pandas.DataFrame
191
+ """
192
+ session = requests.session()
193
+ url = "https://www.soozhu.com/price/data/center/"
194
+ r = session.get(url)
195
+ soup = BeautifulSoup(r.text, features="lxml")
196
+ token = soup.find(name="input", attrs={"name": "csrfmiddlewaretoken"})["value"]
197
+ url = "https://www.soozhu.com/price/data/center/"
198
+ payload = {"act": "pricetrend", "indid": "11", "csrfmiddlewaretoken": token}
199
+ r = session.post(url, data=payload)
200
+ data_json = r.json()
201
+ temp_df = pd.DataFrame(data_json["datalist"])
202
+ temp_df.columns = ["日期", "价格"]
203
+ temp_df["日期"] = pd.to_datetime(temp_df["日期"], errors="coerce").dt.date
204
+ temp_df["价格"] = pd.to_numeric(temp_df["价格"], errors="coerce")
205
+ temp_df.sort_values(by=["日期"], ignore_index=True, inplace=True)
206
+ return temp_df
207
+
208
+
65
209
  if __name__ == "__main__":
66
210
  spot_hog_soozhu_df = spot_hog_soozhu()
67
211
  print(spot_hog_soozhu_df)
68
212
 
69
213
  spot_hog_year_trend_soozhu_df = spot_hog_year_trend_soozhu()
70
214
  print(spot_hog_year_trend_soozhu_df)
215
+
216
+ spot_hog_lean_price_soozhu_df = spot_hog_lean_price_soozhu()
217
+ print(spot_hog_lean_price_soozhu_df)
218
+
219
+ spot_hog_three_way_soozhu_df = spot_hog_three_way_soozhu()
220
+ print(spot_hog_three_way_soozhu_df)
221
+
222
+ spot_hog_crossbred_soozhu_df = spot_hog_crossbred_soozhu()
223
+ print(spot_hog_crossbred_soozhu_df)
224
+
225
+ spot_corn_price_soozhu_df = spot_corn_price_soozhu()
226
+ print(spot_corn_price_soozhu_df)
227
+
228
+ spot_soybean_price_soozhu_df = spot_soybean_price_soozhu()
229
+ print(spot_soybean_price_soozhu_df)
230
+
231
+ spot_mixed_feed_soozhu_df = spot_mixed_feed_soozhu()
232
+ print(spot_mixed_feed_soozhu_df)
akshare/spot/spot_sge.py CHANGED
@@ -1,7 +1,7 @@
1
1
  # -*- coding:utf-8 -*-
2
2
  # !/usr/bin/env python
3
3
  """
4
- Date: 2024/4/22 14:00
4
+ Date: 2025/4/11 22:00
5
5
  Desc: 上海黄金交易所-数据资讯-行情走势
6
6
  https://www.sge.com.cn/sjzx/mrhq
7
7
  上海黄金交易所-数据资讯-上海金基准价-历史数据
@@ -11,6 +11,8 @@ https://www.sge.com.cn/sjzx/mrhq
11
11
  import pandas as pd
12
12
  import requests
13
13
 
14
+ from akshare.utils.cons import headers
15
+
14
16
 
15
17
  def spot_symbol_table_sge() -> pd.DataFrame:
16
18
  """
@@ -45,11 +47,72 @@ def spot_symbol_table_sge() -> pd.DataFrame:
45
47
  return temp_df
46
48
 
47
49
 
50
+ def spot_quotations_sge(symbol: str = "Au99.99") -> pd.DataFrame:
51
+ """
52
+ 上海黄金交易所-实时行情数据
53
+ https://www.sge.com.cn/
54
+ https://www.sge.com.cn/graph/quotations
55
+ :param symbol: choice of {'Au99.99', 'Au99.95', 'Au100g', 'Pt99.95', 'Ag(T+D)', 'Au(T+D)',
56
+ 'mAu(T+D)', 'Au(T+N1)', 'Au(T+N2)', 'Ag99.99', 'iAu99.99', 'Au99.5', 'iAu100g',
57
+ 'iAu99.5', 'PGC30g', 'NYAuTN06', 'NYAuTN12'}; 可以通过 ak.spot_symbol_table_sge() 获取品种表
58
+ :type symbol: str
59
+ :return: 行情数据
60
+ :rtype: pandas.DataFrame
61
+ """
62
+ url = "https://www.sge.com.cn/graph/quotations"
63
+ payload = {"instid": symbol}
64
+ headers = {
65
+ "Accept": "application/json, text/javascript, */*; q=0.01",
66
+ "Accept-Encoding": "gzip, deflate, br, zstd",
67
+ "Accept-Language": "zh-CN,zh;q=0.9,en;q=0.8",
68
+ "Cache-Control": "no-cache",
69
+ "Connection": "keep-alive",
70
+ "Content-Length": "15",
71
+ "Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
72
+ "Host": "www.sge.com.cn",
73
+ "Origin": "https://www.sge.com.cn",
74
+ "Pragma": "no-cache",
75
+ "Referer": "https://www.sge.com.cn/",
76
+ "sec-ch-ua": '"Google Chrome";v="107", "Chromium";v="107", "Not=A?Brand";v="24"',
77
+ "sec-ch-ua-mobile": "?0",
78
+ "sec-ch-ua-platform": '"Windows"',
79
+ "Sec-Fetch-Dest": "empty",
80
+ "Sec-Fetch-Mode": "cors",
81
+ "Sec-Fetch-Site": "same-origin",
82
+ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) "
83
+ "Chrome/107.0.0.0 Safari/537.36",
84
+ "X-Requested-With": "XMLHttpRequest",
85
+ }
86
+ r = requests.get(url, data=payload, headers=headers)
87
+ data_json = r.json()
88
+ temp_df = pd.DataFrame(
89
+ {
90
+ "品种": data_json["heyue"],
91
+ "时间": data_json["times"],
92
+ "现价": data_json["data"],
93
+ "更新时间": data_json["delaystr"],
94
+ }
95
+ )
96
+ temp_df["现价"] = pd.to_numeric(temp_df["现价"], errors="coerce")
97
+ # 将更新时间中的时间部分提取出来
98
+ update_time = temp_df["更新时间"].iloc[0].split()[1]
99
+ # 将时间列转换为时间格式以便排序
100
+ temp_df["时间"] = pd.to_datetime(temp_df["时间"], format="%H:%M").dt.time
101
+ # 过滤掉大于等于更新时间的数据
102
+ temp_df = temp_df[temp_df["时间"].astype(str) < update_time]
103
+ # 按时间排序
104
+ temp_df = temp_df.sort_values(by=["时间"])
105
+ temp_df.reset_index(inplace=True, drop=True)
106
+ return temp_df
107
+
108
+
48
109
  def spot_hist_sge(symbol: str = "Au99.99") -> pd.DataFrame:
49
110
  """
50
111
  上海黄金交易所-数据资讯-行情走势-历史数据
51
112
  https://www.sge.com.cn/sjzx/mrhq
52
- :param symbol: choice of {'Au99.99', 'Au99.95', 'Au100g', 'Pt99.95', 'Ag(T+D)', 'Au(T+D)', 'mAu(T+D)', 'Au(T+N1)', 'Au(T+N2)', 'Ag99.99', 'iAu99.99', 'Au99.5', 'iAu100g', 'iAu99.5', 'PGC30g', 'NYAuTN06', 'NYAuTN12'}; 可以通过 ak.spot_symbol_table_sge() 获取品种表
113
+ :param symbol: choice of {'Au99.99', 'Au99.95', 'Au100g', 'Pt99.95', 'Ag(T+D)', 'Au(T+D)',
114
+ 'mAu(T+D)', 'Au(T+N1)', 'Au(T+N2)', 'Ag99.99', 'iAu99.99', 'Au99.5', 'iAu100g', 'iAu99.5',
115
+ 'PGC30g', 'NYAuTN06', 'NYAuTN12'}; 可以通过 ak.spot_symbol_table_sge() 获取品种表
53
116
  :type symbol: str
54
117
  :return: 历史数据
55
118
  :rtype: pandas.DataFrame
@@ -74,7 +137,8 @@ def spot_hist_sge(symbol: str = "Au99.99") -> pd.DataFrame:
74
137
  "Sec-Fetch-Dest": "empty",
75
138
  "Sec-Fetch-Mode": "cors",
76
139
  "Sec-Fetch-Site": "same-origin",
77
- "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36",
140
+ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) "
141
+ "Chrome/107.0.0.0 Safari/537.36",
78
142
  "X-Requested-With": "XMLHttpRequest",
79
143
  }
80
144
  r = requests.post(url, data=payload, headers=headers)
@@ -105,9 +169,6 @@ def spot_golden_benchmark_sge() -> pd.DataFrame:
105
169
  """
106
170
  url = "https://www.sge.com.cn/graph/DayilyJzj"
107
171
  payload = {}
108
- headers = {
109
- "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36",
110
- }
111
172
  r = requests.post(url, data=payload, headers=headers)
112
173
  data_json = r.json()
113
174
  temp_df = pd.DataFrame(data_json["wp"])
@@ -139,9 +200,6 @@ def spot_silver_benchmark_sge() -> pd.DataFrame:
139
200
  """
140
201
  url = "https://www.sge.com.cn/graph/DayilyShsilverJzj"
141
202
  payload = {}
142
- headers = {
143
- "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36",
144
- }
145
203
  r = requests.post(url, data=payload, headers=headers)
146
204
  data_json = r.json()
147
205
  temp_df = pd.DataFrame(data_json["wp"])
@@ -180,3 +238,6 @@ if __name__ == "__main__":
180
238
  for spot in spot_symbol_table_sge_df["品种"].tolist():
181
239
  spot_hist_sge_df = spot_hist_sge(symbol=spot)
182
240
  print(spot_hist_sge_df)
241
+
242
+ spot_quotations_sge_df = spot_quotations_sge(symbol="Au99.99")
243
+ print(spot_quotations_sge_df)
akshare/stock/cons.py CHANGED
@@ -1,11 +1,15 @@
1
1
  #!/usr/bin/env python
2
2
  # -*- coding:utf-8 -*-
3
3
  """
4
- Date: 2019/10/25 15:56
4
+ Date: 2025/12/12 15:00
5
5
  Desc: 股票配置文件
6
6
  """
7
+
8
+ xq_a_token = "7ed879d430984f6ea5a546808b7b9fcd64f39eb9"
9
+
7
10
  # zh-sina-kcb
8
- zh_sina_kcb_stock_url = "http://vip.stock.finance.sina.com.cn/quotes_service/api/json_v2.php/Market_Center.getHQNodeData"
11
+ zh_sina_kcb_stock_url = ("http://vip.stock.finance.sina.com.cn/quotes_service/api/json_v2.php/"
12
+ "Market_Center.getHQNodeData")
9
13
  zh_sina_kcb_stock_payload = {
10
14
  "page": "1",
11
15
  "num": "80",
@@ -13,11 +17,14 @@ zh_sina_kcb_stock_payload = {
13
17
  "asc": "1",
14
18
  "node": "kcb",
15
19
  "symbol": "",
16
- "_s_r_a": "auto"
20
+ "_s_r_a": "auto",
17
21
  }
18
- zh_sina_kcb_stock_count_url = "http://vip.stock.finance.sina.com.cn/quotes_service/api/json_v2.php/Market_Center.getHQNodeStockCount?node=kcb"
19
- zh_sina_kcb_stock_hist_url = "https://quotes.sina.cn/cn/api/jsonp.php/var%20_{}{}=/KC_MarketDataService.getKLineData?symbol={}"
20
- zh_sina_kcb_stock_amount_url = "https://stock.finance.sina.com.cn/stock/api/jsonp.php/var%20KKE_ShareAmount_{}=/StockService.getAmountBySymbol?_=20&symbol={}"
22
+ zh_sina_kcb_stock_count_url = ("http://vip.stock.finance.sina.com.cn/quotes_service/api/"
23
+ "json_v2.php/Market_Center.getHQNodeStockCount?node=kcb")
24
+ zh_sina_kcb_stock_hist_url = ("https://quotes.sina.cn/cn/api/jsonp.php/var%20_{}{}=/"
25
+ "KC_MarketDataService.getKLineData?symbol={}")
26
+ zh_sina_kcb_stock_amount_url = ("https://stock.finance.sina.com.cn/stock/api/jsonp.php/"
27
+ "var%20KKE_ShareAmount_{}=/StockService.getAmountBySymbol?_=20&symbol={}")
21
28
  zh_sina_kcb_stock_hfq_url = "https://finance.sina.com.cn/realstock/company/{}/hfq.js"
22
29
  zh_sina_kcb_stock_qfq_url = "https://finance.sina.com.cn/realstock/company/{}/qfq.js"
23
30
 
@@ -30,25 +37,34 @@ zh_sina_a_stock_payload = {
30
37
  "asc": "1",
31
38
  "node": "hs_a",
32
39
  "symbol": "",
33
- "_s_r_a": "page"
40
+ "_s_r_a": "page",
34
41
  }
35
- zh_sina_a_stock_count_url = "http://vip.stock.finance.sina.com.cn/quotes_service/api/json_v2.php/Market_Center.getHQNodeStockCount?node=hs_a"
36
- zh_sina_a_stock_hist_url = "https://finance.sina.com.cn/realstock/company/{}/hisdata_klc2/klc_kl.js"
37
- zh_sina_a_stock_amount_url = "https://stock.finance.sina.com.cn/stock/api/jsonp.php/var%20KKE_ShareAmount_{}=/StockService.getAmountBySymbol?_=20&symbol={}"
42
+ zh_sina_a_stock_count_url = ("http://vip.stock.finance.sina.com.cn/quotes_service/api/"
43
+ "json_v2.php/Market_Center.getHQNodeStockCount?node=hs_a")
44
+ zh_sina_a_stock_hist_url = (
45
+ "https://finance.sina.com.cn/realstock/company/{}/hisdata_klc2/klc_kl.js"
46
+ )
47
+ zh_sina_a_stock_amount_url = ("https://stock.finance.sina.com.cn/stock/api/jsonp.php/"
48
+ "var%20KKE_ShareAmount_{}=/StockService.getAmountBySymbol?_=20&symbol={}")
38
49
  zh_sina_a_stock_hfq_url = "https://finance.sina.com.cn/realstock/company/{}/hfq.js"
39
50
  zh_sina_a_stock_qfq_url = "https://finance.sina.com.cn/realstock/company/{}/qfq.js"
40
51
 
41
52
  # us-sina
42
- us_sina_stock_hist_qfq_url = "https://finance.sina.com.cn/us_stock/company/reinstatement/{}_qfq.js"
43
- us_sina_stock_hist_url = "https://finance.sina.com.cn/us_stock/company/hisdata/klc_kl_{}.js"
44
- us_sina_stock_list_url = "http://stock.finance.sina.com.cn/usstock/api/jsonp.php/IO.XSRV2.CallbackList[{}]/US_CategoryService.getList"
53
+ us_sina_stock_hist_qfq_url = (
54
+ "https://finance.sina.com.cn/us_stock/company/reinstatement/{}_qfq.js"
55
+ )
56
+ us_sina_stock_hist_url = (
57
+ "https://finance.sina.com.cn/us_stock/company/hisdata/klc_kl_{}.js"
58
+ )
59
+ us_sina_stock_list_url = ("http://stock.finance.sina.com.cn/usstock/api/jsonp.php"
60
+ "/IO.XSRV2.CallbackList[{}]/US_CategoryService.getList")
45
61
  us_sina_stock_dict_payload = {
46
62
  "page": "2",
47
63
  "num": "20",
48
64
  "sort": "",
49
65
  "asc": "0",
50
66
  "market": "",
51
- "id": ""
67
+ "id": "",
52
68
  }
53
69
  js_hash_text = """
54
70
  function d(s){
@@ -111,7 +127,8 @@ js_hash_text = """
111
127
  hk_sina_stock_hist_hfq_url = "https://finance.sina.com.cn/stock/hkstock/{}/hfq.js"
112
128
  hk_sina_stock_hist_qfq_url = "https://finance.sina.com.cn/stock/hkstock/{}/qfq.js"
113
129
  hk_sina_stock_hist_url = "https://finance.sina.com.cn/stock/hkstock/{}/klc_kl.js"
114
- hk_sina_stock_list_url = "http://vip.stock.finance.sina.com.cn/quotes_service/api/json_v2.php/Market_Center.getHKStockData"
130
+ hk_sina_stock_list_url = ("http://vip.stock.finance.sina.com.cn/quotes_service/api/"
131
+ "json_v2.php/Market_Center.getHKStockData")
115
132
 
116
133
  hk_sina_stock_dict_payload = {
117
134
  "page": "1",
@@ -119,14 +136,15 @@ hk_sina_stock_dict_payload = {
119
136
  "sort": "symbol",
120
137
  "asc": "1",
121
138
  "node": "qbgg_hk",
122
- "_s_r_a": "page"
139
+ "_s_r_a": "page",
123
140
  }
124
141
 
125
142
  # hk-tx
126
143
  hk_url = "http://stock.gtimg.cn/data/hk_rank.php"
127
144
  hk_headers = {
128
145
  "Referer": "http://stockapp.finance.qq.com/mstats/",
129
- "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"
146
+ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 "
147
+ "(KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36",
130
148
  }
131
149
  hk_payload = {
132
150
  "board": "A_H",
@@ -134,18 +152,19 @@ hk_payload = {
134
152
  "pageSize": "20",
135
153
  "reqPage": "1",
136
154
  "order": "decs",
137
- "var_name": "list_data"
155
+ "var_name": "list_data",
138
156
  }
139
157
 
140
158
  hk_stock_url = "http://web.ifzq.gtimg.cn/appstock/app/hkfqkline/get"
141
159
  hk_stock_headers = {
142
160
  # "Referer": "http://gu.qq.com/hk00168/gp",
143
- "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"
161
+ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 "
162
+ "(KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"
144
163
  }
145
164
  hk_stock_payload = {
146
165
  "_var": "kline_dayhfq{}",
147
166
  "param": "hk{},day,{}-01-01,{}-12-31,640,hfq",
148
- "r": ""
167
+ "r": "",
149
168
  }
150
169
 
151
170
  # usa
@@ -154,7 +173,7 @@ payload_usa_daily = {
154
173
  "code": "NASDAQNTES",
155
174
  "start": "20191026213000",
156
175
  "number": "-1000",
157
- "type": "5"
176
+ "type": "5",
158
177
  }
159
178
 
160
179
  # china
@@ -166,11 +185,29 @@ hx_headers = {
166
185
  "Accept-Language": "zh-CN,zh;q=0.9,en;q=0.8",
167
186
  "Cache-Control": "no-cache",
168
187
  "Connection": "keep-alive",
169
- "Cookie": "ADVC=371c0a2afd9a7b; UM_distinctid=16a24d29c4f142-0f969e46eea4c7-e323069-1fa400-16a24d29c50aa5; HexunTrack=SID=20190416142542146f54a3710276640a88fea687ad6a7bcb0&CITY=51&TOWN=510100; vjuids=11fcc219b5.16a820267e4.0.cc0391a93be56; vjlast=1556959357.1556959357.30; __utma=194262068.1423418741.1558975446.1558975446.1558975446.1; __utmz=194262068.1558975446.1.1.utmcsr=baidu|utmccn=(organic)|utmcmd=organic; ASL=18179,anzqo,7ca108c3ded485387ca108c27ca108b97ca108ef; cn_1263247791_dplus=%7B%22distinct_id%22%3A%20%2216a24d29c4f142-0f969e46eea4c7-e323069-1fa400-16a24d29c50aa5%22%2C%22userFirstDate%22%3A%20%2220190504%22%2C%22userID%22%3A%20%22%22%2C%22userName%22%3A%20%22%22%2C%22userType%22%3A%20%22nologinuser%22%2C%22userLoginDate%22%3A%20%2220191010%22%2C%22%24_sessionid%22%3A%200%2C%22%24_sessionTime%22%3A%201570727325%2C%22%24dp%22%3A%200%2C%22%24_sessionPVTime%22%3A%201570727325%2C%22initial_view_time%22%3A%20%221556958609%22%2C%22initial_referrer%22%3A%20%22https%3A%2F%2Fwww.baidu.com%2Flink%3Furl%3DJmHPP1QGABcJs0kzrvZREqHK_nobidR7d7YPCQF75loa5N33Au5q_xFu8y9VPlvl8O6I7b1LmRuhIiccTnFW-_%26wd%3D%26eqid%3Db55837ee0001a310000000025ccd4f55%22%2C%22initial_referrer_domain%22%3A%20%22www.baidu.com%22%2C%22%24recent_outside_referrer%22%3A%20%22www.baidu.com%22%7D; hxck_webdev1_general=bondjlvcookie_list=019124_11%e5%9b%bd%e5%80%ba24_1&npFutjlvcookie_list=czcers1409|WT1009; appToken=pc%2Cother%2Cchrome%2ChxAppSignId96253760252191461570688954189%2CHXGG20190415; __jsluid_h=08f65cba22ad34dc3fd095b5b986c8a4",
188
+ "Cookie": "ADVC=371c0a2afd9a7b; UM_distinctid=16a24d29c4f142-0f969e46eea4c7-e323069-1fa400-16a24d29c50aa5; "
189
+ "HexunTrack=SID=20190416142542146f54a3710276640a88fea687ad6a7bcb0&CITY=51&TOWN=510100; "
190
+ "vjuids=11fcc219b5.16a820267e4.0.cc0391a93be56; vjlast=1556959357.1556959357.30; "
191
+ "__utma=194262068.1423418741.1558975446.1558975446.1558975446.1; "
192
+ "__utmz=194262068.1558975446.1.1.utmcsr=baidu|utmccn=(organic)|utmcmd=organic; "
193
+ "ASL=18179,anzqo,7ca108c3ded485387ca108c27ca108b97ca108ef; "
194
+ "cn_1263247791_dplus=%7B%22distinct_id%22%3A%20%2216a24d29c4f142-0f969e46eea4c7-e323069-1fa400-"
195
+ "16a24d29c50aa5%22%2C%22userFirstDate%22%3A%20%2220190504%22%2C%22userID%22%3A%20%22%22%2C%22us"
196
+ "erName%22%3A%20%22%22%2C%22userType%22%3A%20%22nologinuser%22%2C%22userLoginDate%22%3A%20%2"
197
+ "220191010%22%2C%22%24_sessionid%22%3A%200%2C%22%24_sessionTime%22%3A%201570727325%2C%22%2"
198
+ "4dp%22%3A%200%2C%22%24_sessionPVTime%22%3A%201570727325%2C%22initial_view_time%22%3A%20%"
199
+ "221556958609%22%2C%22initial_referrer%22%3A%20%22https%3A%2F%2Fwww.baidu.com%2Flink%3F"
200
+ "url%3DJmHPP1QGABcJs0kzrvZREqHK_nobidR7d7YPCQF75loa5N33Au5q_xFu8y9VPlvl8O6I7b1LmRuhIicc"
201
+ "TnFW-_%26wd%3D%26eqid%3Db55837ee0001a310000000025ccd4f55%22%2C%22initial_referrer_doma"
202
+ "in%22%3A%20%22www.baidu.com%22%2C%22%24recent_outside_referrer%22%3A%20%22www.baidu.co"
203
+ "m%22%7D; hxck_webdev1_general=bondjlvcookie_list=019124_11%e5%9b%bd%e5%80%ba24_1&npF"
204
+ "utjlvcookie_list=czcers1409|WT1009; appToken=pc%2Cother%2Cchrome%2ChxAppSignId9625376"
205
+ "0252191461570688954189%2CHXGG20190415; __jsluid_h=08f65cba22ad34dc3fd095b5b986c8a4",
170
206
  "Host": "stockdata.stock.hexun.com",
171
207
  "Pragma": "no-cache",
172
208
  "Referer": "http://stockdata.stock.hexun.com/zrbg/",
173
- "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"
209
+ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) "
210
+ "Chrome/77.0.3865.120 Safari/537.36",
174
211
  }
175
212
 
176
213
  hx_params = {
@@ -1,14 +1,14 @@
1
1
  #!/usr/bin/env python
2
2
  # -*- coding:utf-8 -*-
3
3
  """
4
- Date: 2024/6/5 15:00
4
+ Date: 2024/10/22 15:00
5
5
  Desc: 巨潮资讯-数据浏览器-筹资指标-公司配股实施方案
6
- http://webapi.cninfo.com.cn/#/dataBrowse
6
+ https://webapi.cninfo.com.cn/#/dataBrowse
7
7
  """
8
8
 
9
9
  import pandas as pd
10
- import requests
11
10
  import py_mini_racer
11
+ import requests
12
12
 
13
13
  from akshare.datasets import get_ths_js
14
14
 
@@ -32,7 +32,7 @@ def stock_allotment_cninfo(
32
32
  ) -> pd.DataFrame:
33
33
  """
34
34
  巨潮资讯-个股-配股实施方案
35
- http://webapi.cninfo.com.cn/#/dataBrowse
35
+ https://webapi.cninfo.com.cn/#/dataBrowse
36
36
  :param symbol: 股票代码
37
37
  :type symbol: str
38
38
  :param start_date: 开始查询的日期
@@ -42,7 +42,7 @@ def stock_allotment_cninfo(
42
42
  :return: 配股实施方案
43
43
  :rtype: pandas.DataFrame
44
44
  """
45
- url = "http://webapi.cninfo.com.cn/api/stock/p_stock2232"
45
+ url = "https://webapi.cninfo.com.cn/api/stock/p_stock2232"
46
46
  params = {
47
47
  "scode": symbol,
48
48
  "sdate": start_date
@@ -64,10 +64,10 @@ def stock_allotment_cninfo(
64
64
  "Cache-Control": "no-cache",
65
65
  "Content-Length": "0",
66
66
  "Host": "webapi.cninfo.com.cn",
67
- "Origin": "http://webapi.cninfo.com.cn",
67
+ "Origin": "https://webapi.cninfo.com.cn",
68
68
  "Pragma": "no-cache",
69
69
  "Proxy-Connection": "keep-alive",
70
- "Referer": "http://webapi.cninfo.com.cn/",
70
+ "Referer": "https://webapi.cninfo.com.cn/",
71
71
  "X-Requested-With": "XMLHttpRequest",
72
72
  }
73
73
  r = requests.post(url, params=params, headers=headers)
@@ -192,6 +192,6 @@ def stock_allotment_cninfo(
192
192
 
193
193
  if __name__ == "__main__":
194
194
  stock_allotment_cninfo_df = stock_allotment_cninfo(
195
- symbol="600030", start_date="19900101", end_date="20221008"
195
+ symbol="600030", start_date="19900101", end_date="20241022"
196
196
  )
197
197
  print(stock_allotment_cninfo_df)
@@ -1,90 +1,15 @@
1
1
  #!/usr/bin/env python
2
2
  # -*- coding:utf-8 -*-
3
3
  """
4
- Date: 2024/3/20 15:00
4
+ Date: 2025/2/16 18:30
5
5
  Desc: 东方财富-行情报价
6
6
  https://quote.eastmoney.com/sz000001.html
7
7
  """
8
8
 
9
- from functools import lru_cache
10
-
11
9
  import pandas as pd
12
10
  import requests
13
11
 
14
12
 
15
- @lru_cache()
16
- def __code_id_map_em() -> dict:
17
- """
18
- 东方财富-股票和市场代码
19
- https://quote.eastmoney.com/center/gridlist.html#hs_a_board
20
- :return: 股票和市场代码
21
- :rtype: dict
22
- """
23
- url = "https://80.push2.eastmoney.com/api/qt/clist/get"
24
- params = {
25
- "pn": "1",
26
- "pz": "50000",
27
- "po": "1",
28
- "np": "1",
29
- "ut": "bd1d9ddb04089700cf9c27f6f7426281",
30
- "fltt": "2",
31
- "invt": "2",
32
- "fid": "f3",
33
- "fs": "m:1 t:2,m:1 t:23",
34
- "fields": "f12",
35
- "_": "1623833739532",
36
- }
37
- r = requests.get(url, params=params)
38
- data_json = r.json()
39
- if not data_json["data"]["diff"]:
40
- return dict()
41
- temp_df = pd.DataFrame(data_json["data"]["diff"])
42
- temp_df["market_id"] = 1
43
- temp_df.columns = ["sh_code", "sh_id"]
44
- code_id_dict = dict(zip(temp_df["sh_code"], temp_df["sh_id"]))
45
- params = {
46
- "pn": "1",
47
- "pz": "50000",
48
- "po": "1",
49
- "np": "1",
50
- "ut": "bd1d9ddb04089700cf9c27f6f7426281",
51
- "fltt": "2",
52
- "invt": "2",
53
- "fid": "f3",
54
- "fs": "m:0 t:6,m:0 t:80",
55
- "fields": "f12",
56
- "_": "1623833739532",
57
- }
58
- r = requests.get(url, params=params)
59
- data_json = r.json()
60
- if not data_json["data"]["diff"]:
61
- return dict()
62
- temp_df_sz = pd.DataFrame(data_json["data"]["diff"])
63
- temp_df_sz["sz_id"] = 0
64
- code_id_dict.update(dict(zip(temp_df_sz["f12"], temp_df_sz["sz_id"])))
65
- params = {
66
- "pn": "1",
67
- "pz": "50000",
68
- "po": "1",
69
- "np": "1",
70
- "ut": "bd1d9ddb04089700cf9c27f6f7426281",
71
- "fltt": "2",
72
- "invt": "2",
73
- "fid": "f3",
74
- "fs": "m:0 t:81 s:2048",
75
- "fields": "f12",
76
- "_": "1623833739532",
77
- }
78
- r = requests.get(url, params=params)
79
- data_json = r.json()
80
- if not data_json["data"]["diff"]:
81
- return dict()
82
- temp_df_sz = pd.DataFrame(data_json["data"]["diff"])
83
- temp_df_sz["bj_id"] = 0
84
- code_id_dict.update(dict(zip(temp_df_sz["f12"], temp_df_sz["bj_id"])))
85
- return code_id_dict
86
-
87
-
88
13
  def stock_bid_ask_em(symbol: str = "000001") -> pd.DataFrame:
89
14
  """
90
15
  东方财富-行情报价
@@ -95,7 +20,7 @@ def stock_bid_ask_em(symbol: str = "000001") -> pd.DataFrame:
95
20
  :rtype: pandas.DataFrame
96
21
  """
97
22
  url = "https://push2.eastmoney.com/api/qt/stock/get"
98
- code_id_map_em_dict = __code_id_map_em()
23
+ market_code = 1 if symbol.startswith("6") else 0
99
24
  params = {
100
25
  "fltt": "2",
101
26
  "invt": "2",
@@ -107,7 +32,7 @@ def stock_bid_ask_em(symbol: str = "000001") -> pd.DataFrame:
107
32
  "f268,f255,f256,f257,f258,f127,f199,f128,f198,f259,f260,f261,f171,f277,f278,"
108
33
  "f279,f288,f152,f250,f251,f252,f253,f254,f269,f270,f271,f272,f273,f274,f275,"
109
34
  "f276,f265,f266,f289,f290,f286,f285,f292,f293,f294,f295",
110
- "secid": f"{code_id_map_em_dict[symbol]}.{symbol}",
35
+ "secid": f"{market_code}.{symbol}",
111
36
  }
112
37
  r = requests.get(url, params=params)
113
38
  data_json = r.json()