lib-x17-fintech 2.1.3__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 (282) hide show
  1. lib_x17_fintech-2.1.3.dist-info/METADATA +633 -0
  2. lib_x17_fintech-2.1.3.dist-info/RECORD +282 -0
  3. lib_x17_fintech-2.1.3.dist-info/WHEEL +5 -0
  4. lib_x17_fintech-2.1.3.dist-info/licenses/LICENSE +1 -0
  5. lib_x17_fintech-2.1.3.dist-info/top_level.txt +1 -0
  6. xfintech/__init__.py +0 -0
  7. xfintech/connect/__init__.py +18 -0
  8. xfintech/connect/artifact/__init__.py +5 -0
  9. xfintech/connect/artifact/artifact.py +168 -0
  10. xfintech/connect/artifact/tests/__init__.py +3 -0
  11. xfintech/connect/artifact/tests/test_class_artifact_all.py +564 -0
  12. xfintech/connect/common/__init__.py +12 -0
  13. xfintech/connect/common/connect.py +49 -0
  14. xfintech/connect/common/connectref.py +119 -0
  15. xfintech/connect/common/error.py +62 -0
  16. xfintech/connect/common/tests/__init__.py +1 -0
  17. xfintech/connect/common/tests/test_class_connectlike_all.py +544 -0
  18. xfintech/connect/common/tests/test_class_connectref_all.py +586 -0
  19. xfintech/connect/common/tests/test_class_errors_all.py +524 -0
  20. xfintech/connect/instance/__init__.py +7 -0
  21. xfintech/connect/instance/macos.py +121 -0
  22. xfintech/connect/instance/s3.py +176 -0
  23. xfintech/connect/instance/tests/__init__.py +1 -0
  24. xfintech/connect/instance/tests/test_class_macosconnect_all.py +692 -0
  25. xfintech/connect/instance/tests/test_class_s3connect_all.py +603 -0
  26. xfintech/data/__init__.py +20 -0
  27. xfintech/data/common/__init__.py +15 -0
  28. xfintech/data/common/cache.py +186 -0
  29. xfintech/data/common/coolant.py +171 -0
  30. xfintech/data/common/metric.py +138 -0
  31. xfintech/data/common/paginate.py +132 -0
  32. xfintech/data/common/params.py +162 -0
  33. xfintech/data/common/retry.py +201 -0
  34. xfintech/data/common/tests/__init__.py +1 -0
  35. xfintech/data/common/tests/test_class_cache_all.py +681 -0
  36. xfintech/data/common/tests/test_class_coolant_all.py +534 -0
  37. xfintech/data/common/tests/test_class_metric_all.py +705 -0
  38. xfintech/data/common/tests/test_class_paginate_all.py +508 -0
  39. xfintech/data/common/tests/test_class_params_all.py +891 -0
  40. xfintech/data/common/tests/test_class_retry_all.py +714 -0
  41. xfintech/data/job/__init__.py +17 -0
  42. xfintech/data/job/errors.py +112 -0
  43. xfintech/data/job/house.py +156 -0
  44. xfintech/data/job/job.py +247 -0
  45. xfintech/data/job/joblike.py +47 -0
  46. xfintech/data/job/tests/__init__.py +1 -0
  47. xfintech/data/job/tests/test_class_errors_all.py +275 -0
  48. xfintech/data/job/tests/test_class_house_all.py +801 -0
  49. xfintech/data/job/tests/test_class_job_all.py +684 -0
  50. xfintech/data/job/tests/test_class_joblike_all.py +482 -0
  51. xfintech/data/relay/__init__.py +7 -0
  52. xfintech/data/relay/client.py +114 -0
  53. xfintech/data/relay/clientlike.py +45 -0
  54. xfintech/data/relay/tests/test_class_relayclient_all.py +484 -0
  55. xfintech/data/relay/tests/test_class_relayclientlike_all.py +500 -0
  56. xfintech/data/source/__init__.py +7 -0
  57. xfintech/data/source/baostock/__init__.py +21 -0
  58. xfintech/data/source/baostock/job/__init__.py +5 -0
  59. xfintech/data/source/baostock/job/job.py +217 -0
  60. xfintech/data/source/baostock/job/tests/__init__.py +0 -0
  61. xfintech/data/source/baostock/job/tests/test_class_baostockjob_all.py +547 -0
  62. xfintech/data/source/baostock/session/__init__.py +8 -0
  63. xfintech/data/source/baostock/session/relay.py +223 -0
  64. xfintech/data/source/baostock/session/session.py +241 -0
  65. xfintech/data/source/baostock/session/tests/__init__.py +0 -0
  66. xfintech/data/source/baostock/session/tests/test_class_relay_all.py +694 -0
  67. xfintech/data/source/baostock/session/tests/test_class_session_all.py +505 -0
  68. xfintech/data/source/baostock/stock/__init__.py +0 -0
  69. xfintech/data/source/baostock/stock/hs300stock/__init__.py +3 -0
  70. xfintech/data/source/baostock/stock/hs300stock/constant.py +49 -0
  71. xfintech/data/source/baostock/stock/hs300stock/hs300stock.py +133 -0
  72. xfintech/data/source/baostock/stock/hs300stock/tests/__init__.py +1 -0
  73. xfintech/data/source/baostock/stock/hs300stock/tests/test_class_hs300index_all.py +413 -0
  74. xfintech/data/source/baostock/stock/minuteline/__init__.py +19 -0
  75. xfintech/data/source/baostock/stock/minuteline/constant.py +89 -0
  76. xfintech/data/source/baostock/stock/minuteline/minuteline.py +163 -0
  77. xfintech/data/source/baostock/stock/minuteline/tests/__init__.py +0 -0
  78. xfintech/data/source/baostock/stock/minuteline/tests/test_class_minuteline_all.py +582 -0
  79. xfintech/data/source/baostock/stock/stock/__init__.py +19 -0
  80. xfintech/data/source/baostock/stock/stock/constant.py +55 -0
  81. xfintech/data/source/baostock/stock/stock/stock.py +149 -0
  82. xfintech/data/source/baostock/stock/stock/tests/__init__.py +0 -0
  83. xfintech/data/source/baostock/stock/stock/tests/test_class_stock_all.py +508 -0
  84. xfintech/data/source/baostock/stock/stockinfo/__init__.py +5 -0
  85. xfintech/data/source/baostock/stock/stockinfo/constant.py +66 -0
  86. xfintech/data/source/baostock/stock/stockinfo/stockinfo.py +176 -0
  87. xfintech/data/source/baostock/stock/stockinfo/tests/__init__.py +1 -0
  88. xfintech/data/source/baostock/stock/stockinfo/tests/test_class_stockinfo_all.py +617 -0
  89. xfintech/data/source/baostock/stock/sz50stock/__init__.py +3 -0
  90. xfintech/data/source/baostock/stock/sz50stock/constant.py +49 -0
  91. xfintech/data/source/baostock/stock/sz50stock/sz50stock.py +133 -0
  92. xfintech/data/source/baostock/stock/sz50stock/tests/__init__.py +1 -0
  93. xfintech/data/source/baostock/stock/sz50stock/tests/test_class_sz50stock_all.py +397 -0
  94. xfintech/data/source/baostock/stock/tradedate/__init__.py +19 -0
  95. xfintech/data/source/baostock/stock/tradedate/constant.py +72 -0
  96. xfintech/data/source/baostock/stock/tradedate/tests/__init__.py +0 -0
  97. xfintech/data/source/baostock/stock/tradedate/tests/test_class_tradedate_all.py +695 -0
  98. xfintech/data/source/baostock/stock/tradedate/tradedate.py +208 -0
  99. xfintech/data/source/baostock/stock/zz500stock/__init__.py +3 -0
  100. xfintech/data/source/baostock/stock/zz500stock/constant.py +55 -0
  101. xfintech/data/source/baostock/stock/zz500stock/tests/__init__.py +1 -0
  102. xfintech/data/source/baostock/stock/zz500stock/tests/test_class_zz500stock_all.py +421 -0
  103. xfintech/data/source/baostock/stock/zz500stock/zz500stock.py +133 -0
  104. xfintech/data/source/tushare/__init__.py +61 -0
  105. xfintech/data/source/tushare/job/__init__.py +5 -0
  106. xfintech/data/source/tushare/job/job.py +257 -0
  107. xfintech/data/source/tushare/job/tests/test_class_tusharejob_all.py +589 -0
  108. xfintech/data/source/tushare/session/__init__.py +5 -0
  109. xfintech/data/source/tushare/session/relay.py +231 -0
  110. xfintech/data/source/tushare/session/session.py +239 -0
  111. xfintech/data/source/tushare/session/tests/test_class_relay_all.py +719 -0
  112. xfintech/data/source/tushare/session/tests/test_class_session_all.py +705 -0
  113. xfintech/data/source/tushare/stock/__init__.py +55 -0
  114. xfintech/data/source/tushare/stock/adjfactor/__init__.py +19 -0
  115. xfintech/data/source/tushare/stock/adjfactor/adjfactor.py +150 -0
  116. xfintech/data/source/tushare/stock/adjfactor/constant.py +71 -0
  117. xfintech/data/source/tushare/stock/adjfactor/tests/__init__.py +0 -0
  118. xfintech/data/source/tushare/stock/adjfactor/tests/test_class_adjfactor_all.py +372 -0
  119. xfintech/data/source/tushare/stock/capflow/__init__.py +19 -0
  120. xfintech/data/source/tushare/stock/capflow/capflow.py +171 -0
  121. xfintech/data/source/tushare/stock/capflow/constant.py +105 -0
  122. xfintech/data/source/tushare/stock/capflow/tests/__init__.py +0 -0
  123. xfintech/data/source/tushare/stock/capflow/tests/test_class_capflow_all.py +589 -0
  124. xfintech/data/source/tushare/stock/capflowdc/__init__.py +19 -0
  125. xfintech/data/source/tushare/stock/capflowdc/capflowdc.py +167 -0
  126. xfintech/data/source/tushare/stock/capflowdc/constant.py +95 -0
  127. xfintech/data/source/tushare/stock/capflowdc/tests/__init__.py +0 -0
  128. xfintech/data/source/tushare/stock/capflowdc/tests/test_class_capflowdc_all.py +814 -0
  129. xfintech/data/source/tushare/stock/capflowths/__init__.py +19 -0
  130. xfintech/data/source/tushare/stock/capflowths/capflowths.py +173 -0
  131. xfintech/data/source/tushare/stock/capflowths/constant.py +92 -0
  132. xfintech/data/source/tushare/stock/capflowths/tests/__init__.py +0 -0
  133. xfintech/data/source/tushare/stock/capflowths/tests/test_class_capflowths_all.py +551 -0
  134. xfintech/data/source/tushare/stock/company/__init__.py +19 -0
  135. xfintech/data/source/tushare/stock/company/company.py +188 -0
  136. xfintech/data/source/tushare/stock/company/constant.py +92 -0
  137. xfintech/data/source/tushare/stock/company/tests/__init__.py +1 -0
  138. xfintech/data/source/tushare/stock/company/tests/test_class_company_all.py +829 -0
  139. xfintech/data/source/tushare/stock/companybusiness/__init__.py +21 -0
  140. xfintech/data/source/tushare/stock/companybusiness/companybusiness.py +183 -0
  141. xfintech/data/source/tushare/stock/companybusiness/constant.py +91 -0
  142. xfintech/data/source/tushare/stock/companybusiness/tests/__init__.py +0 -0
  143. xfintech/data/source/tushare/stock/companybusiness/tests/test_class_companybusiness_all.py +633 -0
  144. xfintech/data/source/tushare/stock/companycashflow/__init__.py +21 -0
  145. xfintech/data/source/tushare/stock/companycashflow/companycashflow.py +277 -0
  146. xfintech/data/source/tushare/stock/companycashflow/constant.py +293 -0
  147. xfintech/data/source/tushare/stock/companycashflow/tests/__init__.py +0 -0
  148. xfintech/data/source/tushare/stock/companycashflow/tests/test_class_companycashflow_all.py +619 -0
  149. xfintech/data/source/tushare/stock/companydebt/__init__.py +19 -0
  150. xfintech/data/source/tushare/stock/companydebt/companydebt.py +339 -0
  151. xfintech/data/source/tushare/stock/companydebt/constant.py +403 -0
  152. xfintech/data/source/tushare/stock/companydebt/tests/__init__.py +0 -0
  153. xfintech/data/source/tushare/stock/companydebt/tests/test_class_companydebt_all.py +655 -0
  154. xfintech/data/source/tushare/stock/companyoverview/__init__.py +21 -0
  155. xfintech/data/source/tushare/stock/companyoverview/companyoverview.py +214 -0
  156. xfintech/data/source/tushare/stock/companyoverview/constant.py +152 -0
  157. xfintech/data/source/tushare/stock/companyoverview/tests/__init__.py +0 -0
  158. xfintech/data/source/tushare/stock/companyoverview/tests/test_class_companyoverview_all.py +647 -0
  159. xfintech/data/source/tushare/stock/companyprofit/__init__.py +21 -0
  160. xfintech/data/source/tushare/stock/companyprofit/companyprofit.py +272 -0
  161. xfintech/data/source/tushare/stock/companyprofit/constant.py +259 -0
  162. xfintech/data/source/tushare/stock/companyprofit/tests/__init__.py +0 -0
  163. xfintech/data/source/tushare/stock/companyprofit/tests/test_class_companyprofit_all.py +635 -0
  164. xfintech/data/source/tushare/stock/conceptcapflowdc/__init__.py +21 -0
  165. xfintech/data/source/tushare/stock/conceptcapflowdc/conceptcapflowdc.py +175 -0
  166. xfintech/data/source/tushare/stock/conceptcapflowdc/constant.py +106 -0
  167. xfintech/data/source/tushare/stock/conceptcapflowdc/tests/__init__.py +0 -0
  168. xfintech/data/source/tushare/stock/conceptcapflowdc/tests/test_class_conceptcapflowdc_all.py +568 -0
  169. xfintech/data/source/tushare/stock/conceptcapflowths/__init__.py +21 -0
  170. xfintech/data/source/tushare/stock/conceptcapflowths/conceptcapflowths.py +188 -0
  171. xfintech/data/source/tushare/stock/conceptcapflowths/constant.py +89 -0
  172. xfintech/data/source/tushare/stock/conceptcapflowths/tests/__init__.py +0 -0
  173. xfintech/data/source/tushare/stock/conceptcapflowths/tests/test_class_conceptcapflowths_all.py +516 -0
  174. xfintech/data/source/tushare/stock/dayline/__init__.py +19 -0
  175. xfintech/data/source/tushare/stock/dayline/constant.py +87 -0
  176. xfintech/data/source/tushare/stock/dayline/dayline.py +177 -0
  177. xfintech/data/source/tushare/stock/dayline/tests/__init__.py +0 -0
  178. xfintech/data/source/tushare/stock/dayline/tests/test_class_dayline_all.py +585 -0
  179. xfintech/data/source/tushare/stock/industrycapflowths/__init__.py +21 -0
  180. xfintech/data/source/tushare/stock/industrycapflowths/constant.py +89 -0
  181. xfintech/data/source/tushare/stock/industrycapflowths/industrycapflowths.py +192 -0
  182. xfintech/data/source/tushare/stock/industrycapflowths/tests/__init__.py +0 -0
  183. xfintech/data/source/tushare/stock/industrycapflowths/tests/test_class_industrycapflowths_all.py +683 -0
  184. xfintech/data/source/tushare/stock/marketindexcapflowdc/__init__.py +21 -0
  185. xfintech/data/source/tushare/stock/marketindexcapflowdc/constant.py +90 -0
  186. xfintech/data/source/tushare/stock/marketindexcapflowdc/marketindexcapflowdc.py +173 -0
  187. xfintech/data/source/tushare/stock/marketindexcapflowdc/tests/__init__.py +0 -0
  188. xfintech/data/source/tushare/stock/marketindexcapflowdc/tests/test_class_marketindexcapflowdc_all.py +793 -0
  189. xfintech/data/source/tushare/stock/monthline/__init__.py +19 -0
  190. xfintech/data/source/tushare/stock/monthline/constant.py +87 -0
  191. xfintech/data/source/tushare/stock/monthline/monthline.py +180 -0
  192. xfintech/data/source/tushare/stock/monthline/tests/__init__.py +0 -0
  193. xfintech/data/source/tushare/stock/monthline/tests/test_class_monthline_all.py +574 -0
  194. xfintech/data/source/tushare/stock/stock/__init__.py +19 -0
  195. xfintech/data/source/tushare/stock/stock/constant.py +105 -0
  196. xfintech/data/source/tushare/stock/stock/stock.py +193 -0
  197. xfintech/data/source/tushare/stock/stock/tests/__init__.py +0 -0
  198. xfintech/data/source/tushare/stock/stock/tests/test_class_stock_all.py +788 -0
  199. xfintech/data/source/tushare/stock/stockdividend/__init__.py +21 -0
  200. xfintech/data/source/tushare/stock/stockdividend/constant.py +111 -0
  201. xfintech/data/source/tushare/stock/stockdividend/stockdividend.py +180 -0
  202. xfintech/data/source/tushare/stock/stockdividend/tests/__init__.py +0 -0
  203. xfintech/data/source/tushare/stock/stockdividend/tests/test_class_stockdividend_all.py +725 -0
  204. xfintech/data/source/tushare/stock/stockinfo/__init__.py +19 -0
  205. xfintech/data/source/tushare/stock/stockinfo/constant.py +104 -0
  206. xfintech/data/source/tushare/stock/stockinfo/stockinfo.py +208 -0
  207. xfintech/data/source/tushare/stock/stockinfo/tests/__init__.py +0 -0
  208. xfintech/data/source/tushare/stock/stockinfo/tests/test_class_stockinfo_all.py +881 -0
  209. xfintech/data/source/tushare/stock/stockipo/__init__.py +19 -0
  210. xfintech/data/source/tushare/stock/stockipo/constant.py +90 -0
  211. xfintech/data/source/tushare/stock/stockipo/stockipo.py +234 -0
  212. xfintech/data/source/tushare/stock/stockipo/tests/__init__.py +1 -0
  213. xfintech/data/source/tushare/stock/stockipo/tests/test_class_stockipo_all.py +750 -0
  214. xfintech/data/source/tushare/stock/stockpledge/__init__.py +19 -0
  215. xfintech/data/source/tushare/stock/stockpledge/constant.py +72 -0
  216. xfintech/data/source/tushare/stock/stockpledge/stockpledge.py +158 -0
  217. xfintech/data/source/tushare/stock/stockpledge/tests/__init__.py +0 -0
  218. xfintech/data/source/tushare/stock/stockpledge/tests/test_class_stockpledge_all.py +664 -0
  219. xfintech/data/source/tushare/stock/stockpledgedetail/__init__.py +21 -0
  220. xfintech/data/source/tushare/stock/stockpledgedetail/constant.py +85 -0
  221. xfintech/data/source/tushare/stock/stockpledgedetail/stockpledgedetail.py +171 -0
  222. xfintech/data/source/tushare/stock/stockpledgedetail/tests/__init__.py +0 -0
  223. xfintech/data/source/tushare/stock/stockpledgedetail/tests/test_class_stockpledgedetail_all.py +112 -0
  224. xfintech/data/source/tushare/stock/stockst/__init__.py +19 -0
  225. xfintech/data/source/tushare/stock/stockst/constant.py +80 -0
  226. xfintech/data/source/tushare/stock/stockst/stockst.py +189 -0
  227. xfintech/data/source/tushare/stock/stockst/tests/__init__.py +0 -0
  228. xfintech/data/source/tushare/stock/stockst/tests/test_class_stockst_all.py +693 -0
  229. xfintech/data/source/tushare/stock/stocksuspend/__init__.py +21 -0
  230. xfintech/data/source/tushare/stock/stocksuspend/constant.py +75 -0
  231. xfintech/data/source/tushare/stock/stocksuspend/stocksuspend.py +151 -0
  232. xfintech/data/source/tushare/stock/stocksuspend/tests/__init__.py +0 -0
  233. xfintech/data/source/tushare/stock/stocksuspend/tests/test_class_stocksuspend_all.py +626 -0
  234. xfintech/data/source/tushare/stock/techindex/__init__.py +19 -0
  235. xfintech/data/source/tushare/stock/techindex/constant.py +600 -0
  236. xfintech/data/source/tushare/stock/techindex/techindex.py +314 -0
  237. xfintech/data/source/tushare/stock/techindex/tests/__init__.py +0 -0
  238. xfintech/data/source/tushare/stock/techindex/tests/test_class_techindex_all.py +576 -0
  239. xfintech/data/source/tushare/stock/tradedate/__init__.py +19 -0
  240. xfintech/data/source/tushare/stock/tradedate/constant.py +93 -0
  241. xfintech/data/source/tushare/stock/tradedate/tests/__init__.py +0 -0
  242. xfintech/data/source/tushare/stock/tradedate/tests/test_class_tradedate_all.py +947 -0
  243. xfintech/data/source/tushare/stock/tradedate/tradedate.py +234 -0
  244. xfintech/data/source/tushare/stock/weekline/__init__.py +19 -0
  245. xfintech/data/source/tushare/stock/weekline/constant.py +87 -0
  246. xfintech/data/source/tushare/stock/weekline/tests/__init__.py +0 -0
  247. xfintech/data/source/tushare/stock/weekline/tests/test_class_weekline_all.py +575 -0
  248. xfintech/data/source/tushare/stock/weekline/weekline.py +182 -0
  249. xfintech/fabric/__init__.py +18 -0
  250. xfintech/fabric/column/__init__.py +7 -0
  251. xfintech/fabric/column/info.py +202 -0
  252. xfintech/fabric/column/kind.py +102 -0
  253. xfintech/fabric/column/tests/__init__.py +0 -0
  254. xfintech/fabric/column/tests/test_class_info_all.py +207 -0
  255. xfintech/fabric/column/tests/test_class_kind_all.py +80 -0
  256. xfintech/fabric/table/__init__.py +5 -0
  257. xfintech/fabric/table/info.py +263 -0
  258. xfintech/fabric/table/tests/__init__.py +0 -0
  259. xfintech/fabric/table/tests/test_class_info_all.py +547 -0
  260. xfintech/serde/__init__.py +35 -0
  261. xfintech/serde/common/__init__.py +9 -0
  262. xfintech/serde/common/dataformat.py +78 -0
  263. xfintech/serde/common/deserialiserlike.py +38 -0
  264. xfintech/serde/common/error.py +182 -0
  265. xfintech/serde/common/serialiserlike.py +38 -0
  266. xfintech/serde/common/tests/__init__.py +1 -0
  267. xfintech/serde/common/tests/test_class_dataformat_all.py +694 -0
  268. xfintech/serde/common/tests/test_class_deserialiserlike_all.py +500 -0
  269. xfintech/serde/common/tests/test_class_errors_all.py +518 -0
  270. xfintech/serde/common/tests/test_class_serialiserlike_all.py +401 -0
  271. xfintech/serde/deserialiser/__init__.py +7 -0
  272. xfintech/serde/deserialiser/pandas.py +113 -0
  273. xfintech/serde/deserialiser/python.py +68 -0
  274. xfintech/serde/deserialiser/tests/__init__.py +1 -0
  275. xfintech/serde/deserialiser/tests/test_class_pandasdeserialiser_all.py +503 -0
  276. xfintech/serde/deserialiser/tests/test_class_pythondeserialiser_all.py +570 -0
  277. xfintech/serde/serialiser/__init__.py +7 -0
  278. xfintech/serde/serialiser/pandas.py +116 -0
  279. xfintech/serde/serialiser/python.py +71 -0
  280. xfintech/serde/serialiser/tests/__init__.py +1 -0
  281. xfintech/serde/serialiser/tests/test_class_pandasserialiser_all.py +474 -0
  282. xfintech/serde/serialiser/tests/test_class_pythonserialiser_all.py +508 -0
@@ -0,0 +1,214 @@
1
+ from __future__ import annotations
2
+
3
+ from typing import Any, Dict, Optional
4
+
5
+ import pandas as pd
6
+
7
+ from xfintech.data.common.cache import Cache
8
+ from xfintech.data.common.coolant import Coolant
9
+ from xfintech.data.common.params import Params
10
+ from xfintech.data.common.retry import Retry
11
+ from xfintech.data.job import JobHouse
12
+ from xfintech.data.source.tushare.job import TushareJob
13
+ from xfintech.data.source.tushare.session.session import Session
14
+ from xfintech.data.source.tushare.stock.companyoverview.constant import (
15
+ KEY,
16
+ NAME,
17
+ PAGINATE,
18
+ SOURCE,
19
+ TARGET,
20
+ )
21
+
22
+
23
+ @JobHouse.register(KEY, alias=KEY)
24
+ class CompanyOverview(TushareJob):
25
+ """
26
+ 描述:
27
+ - 获取A股上市公司业绩快报数据
28
+ - API文档: https://tushare.pro/document/2?doc_id=46
29
+ - SCALE: CrossSection & Individual
30
+ - TYPE: Partitioned
31
+ - PAGINATE: 1000 rows / 1000 pages
32
+
33
+ 属性:
34
+ - name: str, 作业名称 'companyoverview'。
35
+ - key: str, 作业键 '/tushare/companyoverview'。
36
+ - session: Session, Tushare会话对象。
37
+ - source: TableInfo, 源表信息(Tushare原始格式)。
38
+ - target: TableInfo, 目标表信息(转换后格式)。
39
+ - params: Params, 查询参数。
40
+ - ts_code: str, 必需, 股票代码(如'000001.SZ')
41
+ - ann_date: str, 可选, 公告日期(YYYYMMDD)
42
+ - start_date: str, 可选, 公告开始日期(YYYYMMDD)
43
+ - end_date: str, 可选, 公告结束日期(YYYYMMDD)
44
+ - period: str, 可选, 报告期(如20171231表示年报,20170630半年报)
45
+ - year: str, 可选, 报告年度(YYYY)
46
+ - coolant: Coolant, 请求冷却控制。
47
+ - paginate: Paginate, 分页控制(pagesize=1000, pagelimit=100)。
48
+ - retry: Retry, 重试策略。
49
+ - cache: Cache, 缓存管理。
50
+
51
+ 方法:
52
+ - run(): 执行作业,返回业绩快报DataFrame。
53
+ - _run(): 内部执行逻辑,处理日期参数。
54
+ - transform(data): 转换数据格式,将源格式转为目标格式。
55
+
56
+ 注意:
57
+ - 此数据为个股级别(scale='individual'),必须指定ts_code参数
58
+ - 业绩快报包含营业收入、净利润、总资产等关键财务指标
59
+ - API文档: https://tushare.pro/document/2?doc_id=46
60
+
61
+ 例子:
62
+ ```python
63
+ from xfintech.data.source.tushare.session import Session
64
+ from xfintech.data.source.tushare.stock.companyoverview import CompanyOverview
65
+
66
+ session = Session(credential="your_token")
67
+ overview = CompanyOverview(
68
+ session=session,
69
+ params={
70
+ "ts_code": "000001.SZ",
71
+ "start_date": "20200101",
72
+ "end_date": "20201231",
73
+ },
74
+ )
75
+ df = overview.run()
76
+ ```
77
+ """
78
+
79
+ def __init__(
80
+ self,
81
+ session: Session,
82
+ params: Optional[Params | Dict[str, Any]] = None,
83
+ coolant: Optional[Coolant | Dict[str, Any]] = None,
84
+ retry: Optional[Retry | Dict[str, Any]] = None,
85
+ cache: Optional[Cache | Dict[str, str] | bool] = None,
86
+ ) -> None:
87
+ super().__init__(
88
+ name=NAME,
89
+ key=KEY,
90
+ session=session,
91
+ source=SOURCE,
92
+ target=TARGET,
93
+ params=params,
94
+ coolant=coolant,
95
+ paginate=PAGINATE,
96
+ retry=retry,
97
+ cache=cache,
98
+ )
99
+
100
+ def _run(self) -> pd.DataFrame:
101
+ cached = self._load_cache()
102
+ if cached is not None:
103
+ return cached
104
+
105
+ # Prepare payload dict
106
+ payload = self.params.to_dict()
107
+ payload = self._parse_date_params(
108
+ payload,
109
+ keys=["ann_date", "start_date", "end_date"],
110
+ )
111
+ payload = self._parse_string_params(
112
+ payload,
113
+ keys=["ts_code"],
114
+ )
115
+ payload = self._parse_year_params(
116
+ payload,
117
+ key="year",
118
+ )
119
+ payload = self._parse_period_params(
120
+ payload,
121
+ key="period",
122
+ )
123
+ fields = SOURCE.list_column_names()
124
+ payload["fields"] = ",".join(fields)
125
+
126
+ # Fetch and transform data
127
+ data = self._fetchall(
128
+ api=self.connection.express_vip,
129
+ **payload,
130
+ )
131
+ result = self.transform(data)
132
+ self._save_cache(result)
133
+ return result
134
+
135
+ # Transform logic
136
+ def transform(
137
+ self,
138
+ data: pd.DataFrame,
139
+ ) -> pd.DataFrame:
140
+ cols = self.target.list_column_names()
141
+ if data is None or data.empty:
142
+ return pd.DataFrame(columns=cols)
143
+
144
+ transformed = {}
145
+ transformed["code"] = data["ts_code"].astype(str)
146
+ transformed["datecode"] = data["end_date"].astype(str)
147
+ transformed["date"] = pd.to_datetime(
148
+ data["end_date"],
149
+ format="%Y%m%d",
150
+ errors="coerce",
151
+ ).dt.strftime("%Y-%m-%d")
152
+
153
+ # Convert other date fields
154
+ for col in ["ann_date"]:
155
+ transformed[col] = pd.to_datetime(
156
+ data[col],
157
+ format="%Y%m%d",
158
+ errors="coerce",
159
+ ).dt.strftime("%Y-%m-%d")
160
+
161
+ # Convert string fields
162
+ for col in [
163
+ "perf_summary",
164
+ "remark",
165
+ "is_audit",
166
+ ]:
167
+ if col in data.columns:
168
+ transformed[col] = data[col].astype(str)
169
+
170
+ # Convert numeric fields - all performance express items
171
+ numeric_fields = [
172
+ "revenue",
173
+ "operate_profit",
174
+ "total_profit",
175
+ "n_income",
176
+ "total_assets",
177
+ "total_hldr_eqy_exc_min_int",
178
+ "diluted_eps",
179
+ "diluted_roe",
180
+ "yoy_net_profit",
181
+ "bps",
182
+ "yoy_sales",
183
+ "yoy_op",
184
+ "yoy_tp",
185
+ "yoy_dedu_np",
186
+ "yoy_eps",
187
+ "yoy_roe",
188
+ "growth_assets",
189
+ "yoy_equity",
190
+ "growth_bps",
191
+ "or_last_year",
192
+ "op_last_year",
193
+ "tp_last_year",
194
+ "np_last_year",
195
+ "eps_last_year",
196
+ "open_net_assets",
197
+ "open_bps",
198
+ ]
199
+ for col in numeric_fields:
200
+ if col in data.columns:
201
+ transformed[col] = pd.to_numeric(data[col], errors="coerce")
202
+
203
+ # Ensure all target columns exist (add missing ones with NaN)
204
+ for col in cols:
205
+ if col not in transformed:
206
+ transformed[col] = pd.NA
207
+
208
+ # Select target columns, drop duplicates, and sort
209
+ out = pd.DataFrame(transformed)
210
+ out = out[cols].drop_duplicates()
211
+ out = out.sort_values(by=["code", "date"])
212
+ out = out.reset_index(drop=True)
213
+ self.markpoint("transform[OK]")
214
+ return out
@@ -0,0 +1,152 @@
1
+ from __future__ import annotations
2
+
3
+ from xfintech.data.common.paginate import Paginate
4
+ from xfintech.fabric.column.info import ColumnInfo
5
+ from xfintech.fabric.column.kind import ColumnKind
6
+ from xfintech.fabric.table.info import TableInfo
7
+
8
+ PROVIDER = "tushare"
9
+ SOURCE_NAME = "express_vip"
10
+ URL = "https://tushare.pro/document/2?doc_id=46"
11
+ ARGS = {
12
+ "ts_code": {
13
+ "type": ColumnKind.STRING,
14
+ "required": "Y",
15
+ "desc": "股票代码",
16
+ },
17
+ "ann_date": {
18
+ "type": ColumnKind.STRING,
19
+ "required": "N",
20
+ "desc": "公告日期",
21
+ },
22
+ "start_date": {
23
+ "type": ColumnKind.STRING,
24
+ "required": "N",
25
+ "desc": "公告开始日期",
26
+ },
27
+ "end_date": {
28
+ "type": ColumnKind.STRING,
29
+ "required": "N",
30
+ "desc": "公告结束日期",
31
+ },
32
+ "year": {
33
+ "type": ColumnKind.STRING,
34
+ "required": "N",
35
+ "desc": "年份(YYYY)",
36
+ },
37
+ "period": {
38
+ "type": ColumnKind.STRING,
39
+ "required": "N",
40
+ "desc": "报告期(每个季度最后一天的日期)",
41
+ },
42
+ }
43
+
44
+ # Exported constants
45
+ NAME = "companyoverview"
46
+ KEY = "/tushare/companyoverview"
47
+ PAGINATE = Paginate(
48
+ pagesize=1000,
49
+ pagelimit=1000,
50
+ )
51
+ SOURCE = TableInfo(
52
+ desc="A股业绩快报数据(tushare格式)",
53
+ meta={
54
+ "provider": PROVIDER,
55
+ "source": SOURCE_NAME,
56
+ "url": URL,
57
+ "args": ARGS,
58
+ "type": "partitioned",
59
+ "scale": "crosssection",
60
+ },
61
+ name=SOURCE_NAME,
62
+ columns=[
63
+ ColumnInfo(name="ts_code", kind=ColumnKind.STRING, desc="TS股票代码"),
64
+ ColumnInfo(name="ann_date", kind=ColumnKind.STRING, desc="公告日期"),
65
+ ColumnInfo(name="end_date", kind=ColumnKind.STRING, desc="报告期"),
66
+ ColumnInfo(name="revenue", kind=ColumnKind.FLOAT, desc="营业收入(元)"),
67
+ ColumnInfo(name="operate_profit", kind=ColumnKind.FLOAT, desc="营业利润(元)"),
68
+ ColumnInfo(name="total_profit", kind=ColumnKind.FLOAT, desc="利润总额(元)"),
69
+ ColumnInfo(name="n_income", kind=ColumnKind.FLOAT, desc="净利润(元)"),
70
+ ColumnInfo(name="total_assets", kind=ColumnKind.FLOAT, desc="总资产(元)"),
71
+ ColumnInfo(
72
+ name="total_hldr_eqy_exc_min_int",
73
+ kind=ColumnKind.FLOAT,
74
+ desc="股东权益合计(不含少数股东权益)(元)",
75
+ ),
76
+ ColumnInfo(name="diluted_eps", kind=ColumnKind.FLOAT, desc="每股收益(摊薄)(元)"),
77
+ ColumnInfo(name="diluted_roe", kind=ColumnKind.FLOAT, desc="净资产收益率(摊薄)(%)"),
78
+ ColumnInfo(name="yoy_net_profit", kind=ColumnKind.FLOAT, desc="去年同期修正后净利润"),
79
+ ColumnInfo(name="bps", kind=ColumnKind.FLOAT, desc="每股净资产"),
80
+ ColumnInfo(name="yoy_sales", kind=ColumnKind.FLOAT, desc="同比增长率:营业收入"),
81
+ ColumnInfo(name="yoy_op", kind=ColumnKind.FLOAT, desc="同比增长率:营业利润"),
82
+ ColumnInfo(name="yoy_tp", kind=ColumnKind.FLOAT, desc="同比增长率:利润总额"),
83
+ ColumnInfo(name="yoy_dedu_np", kind=ColumnKind.FLOAT, desc="同比增长率:归属母公司股东的净利润"),
84
+ ColumnInfo(name="yoy_eps", kind=ColumnKind.FLOAT, desc="同比增长率:基本每股收益"),
85
+ ColumnInfo(name="yoy_roe", kind=ColumnKind.FLOAT, desc="同比增减:加权平均净资产收益率"),
86
+ ColumnInfo(name="growth_assets", kind=ColumnKind.FLOAT, desc="比年初增长率:总资产"),
87
+ ColumnInfo(name="yoy_equity", kind=ColumnKind.FLOAT, desc="比年初增长率:归属母公司的股东权益"),
88
+ ColumnInfo(name="growth_bps", kind=ColumnKind.FLOAT, desc="比年初增长率:归属于母公司股东的每股净资产"),
89
+ ColumnInfo(name="or_last_year", kind=ColumnKind.FLOAT, desc="去年同期营业收入"),
90
+ ColumnInfo(name="op_last_year", kind=ColumnKind.FLOAT, desc="去年同期营业利润"),
91
+ ColumnInfo(name="tp_last_year", kind=ColumnKind.FLOAT, desc="去年同期利润总额"),
92
+ ColumnInfo(name="np_last_year", kind=ColumnKind.FLOAT, desc="去年同期净利润"),
93
+ ColumnInfo(name="eps_last_year", kind=ColumnKind.FLOAT, desc="去年同期每股收益"),
94
+ ColumnInfo(name="open_net_assets", kind=ColumnKind.FLOAT, desc="期初净资产"),
95
+ ColumnInfo(name="open_bps", kind=ColumnKind.FLOAT, desc="期初每股净资产"),
96
+ ColumnInfo(name="perf_summary", kind=ColumnKind.STRING, desc="业绩简要说明"),
97
+ ColumnInfo(name="is_audit", kind=ColumnKind.INTEGER, desc="是否审计: 1是 0否"),
98
+ ColumnInfo(name="remark", kind=ColumnKind.STRING, desc="备注"),
99
+ ],
100
+ )
101
+
102
+ TARGET = TableInfo(
103
+ desc="A股业绩快报数据(标准格式)",
104
+ meta={
105
+ "provider": PROVIDER,
106
+ "source": SOURCE_NAME,
107
+ "url": URL,
108
+ "args": ARGS,
109
+ "type": "partitioned",
110
+ "scale": "individual",
111
+ },
112
+ name=NAME,
113
+ columns=[
114
+ ColumnInfo(name="code", kind=ColumnKind.STRING, desc="股票代码"),
115
+ ColumnInfo(name="date", kind=ColumnKind.STRING, desc="报告期日期"),
116
+ ColumnInfo(name="datecode", kind=ColumnKind.STRING, desc="报告期日期代码"),
117
+ ColumnInfo(name="ann_date", kind=ColumnKind.STRING, desc="公告日期"),
118
+ ColumnInfo(name="revenue", kind=ColumnKind.FLOAT, desc="营业收入(元)"),
119
+ ColumnInfo(name="operate_profit", kind=ColumnKind.FLOAT, desc="营业利润(元)"),
120
+ ColumnInfo(name="total_profit", kind=ColumnKind.FLOAT, desc="利润总额(元)"),
121
+ ColumnInfo(name="n_income", kind=ColumnKind.FLOAT, desc="净利润(元)"),
122
+ ColumnInfo(name="total_assets", kind=ColumnKind.FLOAT, desc="总资产(元)"),
123
+ ColumnInfo(
124
+ name="total_hldr_eqy_exc_min_int",
125
+ kind=ColumnKind.FLOAT,
126
+ desc="股东权益合计(不含少数股东权益)(元)",
127
+ ),
128
+ ColumnInfo(name="diluted_eps", kind=ColumnKind.FLOAT, desc="每股收益(摊薄)(元)"),
129
+ ColumnInfo(name="diluted_roe", kind=ColumnKind.FLOAT, desc="净资产收益率(摊薄)(%)"),
130
+ ColumnInfo(name="yoy_net_profit", kind=ColumnKind.FLOAT, desc="去年同期修正后净利润"),
131
+ ColumnInfo(name="bps", kind=ColumnKind.FLOAT, desc="每股净资产"),
132
+ ColumnInfo(name="yoy_sales", kind=ColumnKind.FLOAT, desc="同比增长率:营业收入"),
133
+ ColumnInfo(name="yoy_op", kind=ColumnKind.FLOAT, desc="同比增长率:营业利润"),
134
+ ColumnInfo(name="yoy_tp", kind=ColumnKind.FLOAT, desc="同比增长率:利润总额"),
135
+ ColumnInfo(name="yoy_dedu_np", kind=ColumnKind.FLOAT, desc="同比增长率:归属母公司股东的净利润"),
136
+ ColumnInfo(name="yoy_eps", kind=ColumnKind.FLOAT, desc="同比增长率:基本每股收益"),
137
+ ColumnInfo(name="yoy_roe", kind=ColumnKind.FLOAT, desc="同比增减:加权平均净资产收益率"),
138
+ ColumnInfo(name="growth_assets", kind=ColumnKind.FLOAT, desc="比年初增长率:总资产"),
139
+ ColumnInfo(name="yoy_equity", kind=ColumnKind.FLOAT, desc="比年初增长率:归属母公司的股东权益"),
140
+ ColumnInfo(name="growth_bps", kind=ColumnKind.FLOAT, desc="比年初增长率:归属于母公司股东的每股净资产"),
141
+ ColumnInfo(name="or_last_year", kind=ColumnKind.FLOAT, desc="去年同期营业收入"),
142
+ ColumnInfo(name="op_last_year", kind=ColumnKind.FLOAT, desc="去年同期营业利润"),
143
+ ColumnInfo(name="tp_last_year", kind=ColumnKind.FLOAT, desc="去年同期利润总额"),
144
+ ColumnInfo(name="np_last_year", kind=ColumnKind.FLOAT, desc="去年同期净利润"),
145
+ ColumnInfo(name="eps_last_year", kind=ColumnKind.FLOAT, desc="去年同期每股收益"),
146
+ ColumnInfo(name="open_net_assets", kind=ColumnKind.FLOAT, desc="期初净资产"),
147
+ ColumnInfo(name="open_bps", kind=ColumnKind.FLOAT, desc="期初每股净资产"),
148
+ ColumnInfo(name="perf_summary", kind=ColumnKind.STRING, desc="业绩简要说明"),
149
+ ColumnInfo(name="is_audit", kind=ColumnKind.INTEGER, desc="是否审计: 1是 0否"),
150
+ ColumnInfo(name="remark", kind=ColumnKind.STRING, desc="备注"),
151
+ ],
152
+ )