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,272 @@
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.companyprofit.constant import (
15
+ KEY,
16
+ NAME,
17
+ PAGINATE,
18
+ SOURCE,
19
+ TARGET,
20
+ )
21
+
22
+
23
+ @JobHouse.register(KEY, alias=KEY)
24
+ class CompanyProfit(TushareJob):
25
+ """
26
+ 描述:
27
+ - 获取A股上市公司利润表数据
28
+ - API文档: https://tushare.pro/document/2?doc_id=33
29
+ - SCALE: CrossSection & Individual
30
+ - TYPE: Partitioned
31
+ - PAGINATE: 1000 rows / 1000 pages
32
+
33
+ 属性:
34
+ - name: str, 作业名称 'companyprofit'。
35
+ - key: str, 作业键 '/tushare/companyprofit'。
36
+ - session: Session, Tushare会话对象。
37
+ - source: TableInfo, 源表信息(Tushare原始格式)。
38
+ - target: TableInfo, 目标表信息(转换后格式)。
39
+ - params: Params, 查询参数。
40
+ - ts_code: str, 必需, 股票代码(如'000001.SZ')
41
+ - start_date: str, 可选, 开始日期(YYYYMMDD)
42
+ - end_date: str, 可选, 结束日期(YYYYMMDD)
43
+ - period: str, 可选, 报告期(如20171231表示年报,20170630半年报)
44
+ - year: str, 可选, 报告年度(YYYY)
45
+ - coolant: Coolant, 请求冷却控制。
46
+ - paginate: Paginate, 分页控制(pagesize=1000, pagelimit=100)。
47
+ - retry: Retry, 重试策略。
48
+ - cache: Cache, 缓存管理。
49
+
50
+ 方法:
51
+ - run(): 执行作业,返回利润表DataFrame。
52
+ - _run(): 内部执行逻辑,处理日期参数。
53
+ - transform(data): 转换数据格式,将源格式转为目标格式。
54
+
55
+ 例子:
56
+ ```python
57
+ from xfintech.data.source.tushare.session import Session
58
+ from xfintech.data.source.tushare.stock.companyprofit import CompanyProfit
59
+
60
+ session = Session(credential="your_token")
61
+ profit = CompanyProfit(
62
+ session=session,
63
+ params={
64
+ "ts_code": "000001.SZ",
65
+ "start_date": "20200101",
66
+ "end_date": "20201231",
67
+ },
68
+ )
69
+ df = profit.run()
70
+ ```
71
+ """
72
+
73
+ def __init__(
74
+ self,
75
+ session: Session,
76
+ params: Optional[Params | Dict[str, Any]] = None,
77
+ coolant: Optional[Coolant | Dict[str, Any]] = None,
78
+ retry: Optional[Retry | Dict[str, Any]] = None,
79
+ cache: Optional[Cache | Dict[str, str] | bool] = None,
80
+ ) -> None:
81
+ super().__init__(
82
+ name=NAME,
83
+ key=KEY,
84
+ session=session,
85
+ source=SOURCE,
86
+ target=TARGET,
87
+ params=params,
88
+ coolant=coolant,
89
+ paginate=PAGINATE,
90
+ retry=retry,
91
+ cache=cache,
92
+ )
93
+
94
+ def _run(self) -> pd.DataFrame:
95
+ cached = self._load_cache()
96
+ if cached is not None:
97
+ return cached
98
+
99
+ # Prepare payload dict
100
+ payload = self.params.to_dict()
101
+ payload = self._parse_date_params(
102
+ payload,
103
+ keys=["ann_date", "start_date", "end_date"],
104
+ )
105
+ payload = self._parse_string_params(
106
+ payload,
107
+ keys=["ts_code"],
108
+ )
109
+ payload = self._parse_year_params(
110
+ payload,
111
+ key="year",
112
+ )
113
+ payload = self._parse_period_params(
114
+ payload,
115
+ key="period",
116
+ )
117
+ fields = SOURCE.list_column_names()
118
+ payload["fields"] = ",".join(fields)
119
+
120
+ # Fetch and transform data
121
+ data = self._fetchall(
122
+ api=self.connection.income_vip,
123
+ **payload,
124
+ )
125
+ result = self.transform(data)
126
+ self._save_cache(result)
127
+ return result
128
+
129
+ # Transform logic
130
+ def transform(
131
+ self,
132
+ data: pd.DataFrame,
133
+ ) -> pd.DataFrame:
134
+ cols = self.target.list_column_names()
135
+ if data is None or data.empty:
136
+ return pd.DataFrame(columns=cols)
137
+
138
+ transformed = {}
139
+ transformed["code"] = data["ts_code"].astype(str)
140
+ transformed["datecode"] = data["end_date"].astype(str)
141
+ transformed["date"] = pd.to_datetime(
142
+ data["end_date"],
143
+ format="%Y%m%d",
144
+ errors="coerce",
145
+ ).dt.strftime("%Y-%m-%d")
146
+
147
+ # Convert other date fields
148
+ for col in [
149
+ "ann_date",
150
+ "f_ann_date",
151
+ "end_date",
152
+ ]:
153
+ transformed[col] = pd.to_datetime(
154
+ data[col],
155
+ format="%Y%m%d",
156
+ errors="coerce",
157
+ ).dt.strftime("%Y-%m-%d")
158
+
159
+ # Convert string fields
160
+ for col in [
161
+ "report_type",
162
+ "comp_type",
163
+ "end_type",
164
+ "update_flag",
165
+ ]:
166
+ transformed[col] = data[col].astype(str)
167
+
168
+ # Convert numeric fields
169
+ numeric_fields = [
170
+ "basic_eps",
171
+ "diluted_eps",
172
+ "total_revenue",
173
+ "revenue",
174
+ "int_income",
175
+ "prem_earned",
176
+ "comm_income",
177
+ "n_commis_income",
178
+ "n_oth_income",
179
+ "n_oth_b_income",
180
+ "prem_income",
181
+ "out_prem",
182
+ "une_prem_reser",
183
+ "reins_income",
184
+ "n_sec_tb_income",
185
+ "n_sec_uw_income",
186
+ "n_asset_mg_income",
187
+ "oth_b_income",
188
+ "fv_value_chg_gain",
189
+ "invest_income",
190
+ "ass_invest_income",
191
+ "forex_gain",
192
+ "total_cogs",
193
+ "oper_cost",
194
+ "int_exp",
195
+ "comm_exp",
196
+ "biz_tax_surchg",
197
+ "sell_exp",
198
+ "admin_exp",
199
+ "fin_exp",
200
+ "assets_impair_loss",
201
+ "prem_refund",
202
+ "compens_payout",
203
+ "reser_insur_liab",
204
+ "div_payt",
205
+ "reins_exp",
206
+ "oper_exp",
207
+ "compens_payout_refu",
208
+ "insur_reser_refu",
209
+ "reins_cost_refund",
210
+ "other_bus_cost",
211
+ "operate_profit",
212
+ "non_oper_income",
213
+ "non_oper_exp",
214
+ "nca_disploss",
215
+ "total_profit",
216
+ "income_tax",
217
+ "n_income",
218
+ "n_income_attr_p",
219
+ "minority_gain",
220
+ "oth_compr_income",
221
+ "t_compr_income",
222
+ "compr_inc_attr_p",
223
+ "compr_inc_attr_m_s",
224
+ "ebit",
225
+ "ebitda",
226
+ "insurance_exp",
227
+ "undist_profit",
228
+ "distable_profit",
229
+ "rd_exp",
230
+ "fin_exp_int_exp",
231
+ "fin_exp_int_inc",
232
+ "transfer_surplus_rese",
233
+ "transfer_housing_imprest",
234
+ "transfer_oth",
235
+ "adj_lossgain",
236
+ "withdra_legal_surplus",
237
+ "withdra_legal_pubfund",
238
+ "withdra_biz_devfund",
239
+ "withdra_rese_fund",
240
+ "withdra_oth_ersu",
241
+ "workers_welfare",
242
+ "distr_profit_shrhder",
243
+ "prfshare_payable_dvd",
244
+ "comshare_payable_dvd",
245
+ "capit_comstock_div",
246
+ "net_after_nr_lp_correct",
247
+ "credit_impa_loss",
248
+ "net_expo_hedging_benefits",
249
+ "oth_impair_loss_assets",
250
+ "total_opcost",
251
+ "amodcost_fin_assets",
252
+ "oth_income",
253
+ "asset_disp_income",
254
+ "continued_net_profit",
255
+ "end_net_profit",
256
+ ]
257
+ for col in numeric_fields:
258
+ if col in data.columns:
259
+ transformed[col] = pd.to_numeric(data[col], errors="coerce")
260
+
261
+ # Ensure all target columns exist (add missing ones with NaN)
262
+ for col in cols:
263
+ if col not in transformed:
264
+ transformed[col] = pd.NA
265
+
266
+ # Select target columns, drop duplicates, and sort
267
+ out = pd.DataFrame(transformed)
268
+ out = out[cols].drop_duplicates()
269
+ out = out.sort_values(by=["code", "date"])
270
+ out = out.reset_index(drop=True)
271
+ self.markpoint("transform[OK]")
272
+ return out
@@ -0,0 +1,259 @@
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 = "income_vip"
10
+ URL = "https://tushare.pro/document/2?doc_id=33"
11
+ ARGS = {
12
+ "ts_code": {
13
+ "type": ColumnKind.STRING,
14
+ "required": "Y",
15
+ "desc": "股票代码",
16
+ },
17
+ "start_date": {
18
+ "type": ColumnKind.STRING,
19
+ "required": "N",
20
+ "desc": "开始日期(YYYYMMDD)",
21
+ },
22
+ "end_date": {
23
+ "type": ColumnKind.STRING,
24
+ "required": "N",
25
+ "desc": "结束日期(YYYYMMDD)",
26
+ },
27
+ "year": {
28
+ "type": ColumnKind.STRING,
29
+ "required": "N",
30
+ "desc": "年份(YYYY)",
31
+ },
32
+ "period": {
33
+ "type": ColumnKind.STRING,
34
+ "required": "N",
35
+ "desc": "报告期(每个季度最后一天的日期)",
36
+ },
37
+ }
38
+
39
+ # Exported constants
40
+ NAME = "companyprofit"
41
+ KEY = "/tushare/companyprofit"
42
+ PAGINATE = Paginate(
43
+ pagesize=1000,
44
+ pagelimit=1000,
45
+ )
46
+ SOURCE = TableInfo(
47
+ desc="A股利润表数据(tushare格式)",
48
+ meta={
49
+ "provider": PROVIDER,
50
+ "source": SOURCE_NAME,
51
+ "url": URL,
52
+ "args": ARGS,
53
+ "type": "partitioned",
54
+ "scale": "crosssection",
55
+ },
56
+ columns=[
57
+ ColumnInfo(name="ts_code", kind=ColumnKind.STRING, desc="TS代码"),
58
+ ColumnInfo(name="ann_date", kind=ColumnKind.STRING, desc="公告日期"),
59
+ ColumnInfo(name="f_ann_date", kind=ColumnKind.STRING, desc="实际公告日期"),
60
+ ColumnInfo(name="end_date", kind=ColumnKind.STRING, desc="报告期"),
61
+ ColumnInfo(name="report_type", kind=ColumnKind.STRING, desc="报告类型 见底部表"),
62
+ ColumnInfo(name="comp_type", kind=ColumnKind.STRING, desc="公司类型(1一般工商业2银行3保险4证券)"),
63
+ ColumnInfo(name="end_type", kind=ColumnKind.STRING, desc="报告期类型"),
64
+ ColumnInfo(name="update_flag", kind=ColumnKind.STRING, desc="更新标识"),
65
+ ColumnInfo(name="basic_eps", kind=ColumnKind.FLOAT, desc="基本每股收益"),
66
+ ColumnInfo(name="diluted_eps", kind=ColumnKind.FLOAT, desc="稀释每股收益"),
67
+ ColumnInfo(name="total_revenue", kind=ColumnKind.FLOAT, desc="营业总收入"),
68
+ ColumnInfo(name="revenue", kind=ColumnKind.FLOAT, desc="营业收入"),
69
+ ColumnInfo(name="int_income", kind=ColumnKind.FLOAT, desc="利息收入"),
70
+ ColumnInfo(name="prem_earned", kind=ColumnKind.FLOAT, desc="已赚保费"),
71
+ ColumnInfo(name="comm_income", kind=ColumnKind.FLOAT, desc="手续费及佣金收入"),
72
+ ColumnInfo(name="n_commis_income", kind=ColumnKind.FLOAT, desc="手续费及佣金净收入"),
73
+ ColumnInfo(name="n_oth_income", kind=ColumnKind.FLOAT, desc="其他经营净收益"),
74
+ ColumnInfo(name="n_oth_b_income", kind=ColumnKind.FLOAT, desc="加:其他业务净收益"),
75
+ ColumnInfo(name="prem_income", kind=ColumnKind.FLOAT, desc="保险业务收入"),
76
+ ColumnInfo(name="out_prem", kind=ColumnKind.FLOAT, desc="减:分出保费"),
77
+ ColumnInfo(name="une_prem_reser", kind=ColumnKind.FLOAT, desc="提取未到期责任准备金"),
78
+ ColumnInfo(name="reins_income", kind=ColumnKind.FLOAT, desc="其中:分保费收入"),
79
+ ColumnInfo(name="n_sec_tb_income", kind=ColumnKind.FLOAT, desc="代理买卖证券业务净收入"),
80
+ ColumnInfo(name="n_sec_uw_income", kind=ColumnKind.FLOAT, desc="证券承销业务净收入"),
81
+ ColumnInfo(name="n_asset_mg_income", kind=ColumnKind.FLOAT, desc="受托客户资产管理业务净收入"),
82
+ ColumnInfo(name="oth_b_income", kind=ColumnKind.FLOAT, desc="其他业务收入"),
83
+ ColumnInfo(name="fv_value_chg_gain", kind=ColumnKind.FLOAT, desc="加:公允价值变动净收益"),
84
+ ColumnInfo(name="invest_income", kind=ColumnKind.FLOAT, desc="加:投资净收益"),
85
+ ColumnInfo(name="ass_invest_income", kind=ColumnKind.FLOAT, desc="其中:对联营企业和合营企业的投资收益"),
86
+ ColumnInfo(name="forex_gain", kind=ColumnKind.FLOAT, desc="加:汇兑净收益"),
87
+ ColumnInfo(name="total_cogs", kind=ColumnKind.FLOAT, desc="营业总成本"),
88
+ ColumnInfo(name="oper_cost", kind=ColumnKind.FLOAT, desc="减:营业成本"),
89
+ ColumnInfo(name="int_exp", kind=ColumnKind.FLOAT, desc="减:利息支出"),
90
+ ColumnInfo(name="comm_exp", kind=ColumnKind.FLOAT, desc="减:手续费及佣金支出"),
91
+ ColumnInfo(name="biz_tax_surchg", kind=ColumnKind.FLOAT, desc="减:营业税金及附加"),
92
+ ColumnInfo(name="sell_exp", kind=ColumnKind.FLOAT, desc="减:销售费用"),
93
+ ColumnInfo(name="admin_exp", kind=ColumnKind.FLOAT, desc="减:管理费用"),
94
+ ColumnInfo(name="fin_exp", kind=ColumnKind.FLOAT, desc="减:财务费用"),
95
+ ColumnInfo(name="assets_impair_loss", kind=ColumnKind.FLOAT, desc="减:资产减值损失"),
96
+ ColumnInfo(name="prem_refund", kind=ColumnKind.FLOAT, desc="退保金"),
97
+ ColumnInfo(name="compens_payout", kind=ColumnKind.FLOAT, desc="赔付总支出"),
98
+ ColumnInfo(name="reser_insur_liab", kind=ColumnKind.FLOAT, desc="提取保险责任准备金"),
99
+ ColumnInfo(name="div_payt", kind=ColumnKind.FLOAT, desc="保户红利支出"),
100
+ ColumnInfo(name="reins_exp", kind=ColumnKind.FLOAT, desc="分保费用"),
101
+ ColumnInfo(name="oper_exp", kind=ColumnKind.FLOAT, desc="营业支出"),
102
+ ColumnInfo(name="compens_payout_refu", kind=ColumnKind.FLOAT, desc="减:摊回赔付支出"),
103
+ ColumnInfo(name="insur_reser_refu", kind=ColumnKind.FLOAT, desc="减:摊回保险责任准备金"),
104
+ ColumnInfo(name="reins_cost_refund", kind=ColumnKind.FLOAT, desc="减:摊回分保费用"),
105
+ ColumnInfo(name="other_bus_cost", kind=ColumnKind.FLOAT, desc="其他业务成本"),
106
+ ColumnInfo(name="operate_profit", kind=ColumnKind.FLOAT, desc="营业利润"),
107
+ ColumnInfo(name="non_oper_income", kind=ColumnKind.FLOAT, desc="加:营业外收入"),
108
+ ColumnInfo(name="non_oper_exp", kind=ColumnKind.FLOAT, desc="减:营业外支出"),
109
+ ColumnInfo(name="nca_disploss", kind=ColumnKind.FLOAT, desc="其中:减:非流动资产处置净损失"),
110
+ ColumnInfo(name="total_profit", kind=ColumnKind.FLOAT, desc="利润总额"),
111
+ ColumnInfo(name="income_tax", kind=ColumnKind.FLOAT, desc="所得税费用"),
112
+ ColumnInfo(name="n_income", kind=ColumnKind.FLOAT, desc="净利润(含少数股东损益)"),
113
+ ColumnInfo(name="n_income_attr_p", kind=ColumnKind.FLOAT, desc="净利润(不含少数股东损益)"),
114
+ ColumnInfo(name="minority_gain", kind=ColumnKind.FLOAT, desc="少数股东损益"),
115
+ ColumnInfo(name="oth_compr_income", kind=ColumnKind.FLOAT, desc="其他综合收益"),
116
+ ColumnInfo(name="t_compr_income", kind=ColumnKind.FLOAT, desc="综合收益总额"),
117
+ ColumnInfo(name="compr_inc_attr_p", kind=ColumnKind.FLOAT, desc="归属于母公司(或股东)的综合收益总额"),
118
+ ColumnInfo(name="compr_inc_attr_m_s", kind=ColumnKind.FLOAT, desc="归属于少数股东的综合收益总额"),
119
+ ColumnInfo(name="ebit", kind=ColumnKind.FLOAT, desc="息税前利润"),
120
+ ColumnInfo(name="ebitda", kind=ColumnKind.FLOAT, desc="息税折旧摊销前利润"),
121
+ ColumnInfo(name="insurance_exp", kind=ColumnKind.FLOAT, desc="保险业务支出"),
122
+ ColumnInfo(name="undist_profit", kind=ColumnKind.FLOAT, desc="年初未分配利润"),
123
+ ColumnInfo(name="distable_profit", kind=ColumnKind.FLOAT, desc="可分配利润"),
124
+ ColumnInfo(name="rd_exp", kind=ColumnKind.FLOAT, desc="研发费用"),
125
+ ColumnInfo(name="fin_exp_int_exp", kind=ColumnKind.FLOAT, desc="财务费用:利息费用"),
126
+ ColumnInfo(name="fin_exp_int_inc", kind=ColumnKind.FLOAT, desc="财务费用:利息收入"),
127
+ ColumnInfo(name="transfer_surplus_rese", kind=ColumnKind.FLOAT, desc="盈余公积转入"),
128
+ ColumnInfo(name="transfer_housing_imprest", kind=ColumnKind.FLOAT, desc="住房周转金转入"),
129
+ ColumnInfo(name="transfer_oth", kind=ColumnKind.FLOAT, desc="其他转入"),
130
+ ColumnInfo(name="adj_lossgain", kind=ColumnKind.FLOAT, desc="调整以前年度损益"),
131
+ ColumnInfo(name="withdra_legal_surplus", kind=ColumnKind.FLOAT, desc="提取法定盈余公积"),
132
+ ColumnInfo(name="withdra_legal_pubfund", kind=ColumnKind.FLOAT, desc="提取法定公益金"),
133
+ ColumnInfo(name="withdra_biz_devfund", kind=ColumnKind.FLOAT, desc="提取企业发展基金"),
134
+ ColumnInfo(name="withdra_rese_fund", kind=ColumnKind.FLOAT, desc="提取储备基金"),
135
+ ColumnInfo(name="withdra_oth_ersu", kind=ColumnKind.FLOAT, desc="提取任意盈余公积金"),
136
+ ColumnInfo(name="workers_welfare", kind=ColumnKind.FLOAT, desc="职工奖金福利"),
137
+ ColumnInfo(name="distr_profit_shrhder", kind=ColumnKind.FLOAT, desc="可供股东分配的利润"),
138
+ ColumnInfo(name="prfshare_payable_dvd", kind=ColumnKind.FLOAT, desc="应付优先股股利"),
139
+ ColumnInfo(name="comshare_payable_dvd", kind=ColumnKind.FLOAT, desc="应付普通股股利"),
140
+ ColumnInfo(name="capit_comstock_div", kind=ColumnKind.FLOAT, desc="转作股本的普通股股利"),
141
+ ColumnInfo(name="net_after_nr_lp_correct", kind=ColumnKind.FLOAT, desc="扣除非经常性损益后的净利润(更正前)"),
142
+ ColumnInfo(name="credit_impa_loss", kind=ColumnKind.FLOAT, desc="信用减值损失"),
143
+ ColumnInfo(name="net_expo_hedging_benefits", kind=ColumnKind.FLOAT, desc="净敞口套期收益"),
144
+ ColumnInfo(name="oth_impair_loss_assets", kind=ColumnKind.FLOAT, desc="其他资产减值损失"),
145
+ ColumnInfo(name="total_opcost", kind=ColumnKind.FLOAT, desc="营业总成本(二)"),
146
+ ColumnInfo(name="amodcost_fin_assets", kind=ColumnKind.FLOAT, desc="以摊余成本计量的金融资产终止确认收益"),
147
+ ColumnInfo(name="oth_income", kind=ColumnKind.FLOAT, desc="其他收益"),
148
+ ColumnInfo(name="asset_disp_income", kind=ColumnKind.FLOAT, desc="资产处置收益"),
149
+ ColumnInfo(name="continued_net_profit", kind=ColumnKind.FLOAT, desc="持续经营净利润"),
150
+ ColumnInfo(name="end_net_profit", kind=ColumnKind.FLOAT, desc="终止经营净利润"),
151
+ ],
152
+ )
153
+ TARGET = TableInfo(
154
+ desc="A股利润表数据(xfintech格式)",
155
+ meta={
156
+ "key": KEY,
157
+ "name": NAME,
158
+ "type": "partitioned",
159
+ "scale": "crosssection",
160
+ },
161
+ columns=[
162
+ ColumnInfo(name="code", kind=ColumnKind.STRING, desc="TS代码"),
163
+ ColumnInfo(name="date", kind=ColumnKind.STRING, desc="报告期日期(YYYY-MM-DD)"),
164
+ ColumnInfo(name="datecode", kind=ColumnKind.STRING, desc="报告期日期码(YYYYMMDD)"),
165
+ ColumnInfo(name="ann_date", kind=ColumnKind.STRING, desc="公告日期"),
166
+ ColumnInfo(name="f_ann_date", kind=ColumnKind.STRING, desc="实际公告日期"),
167
+ ColumnInfo(name="end_date", kind=ColumnKind.STRING, desc="报告期"),
168
+ ColumnInfo(name="report_type", kind=ColumnKind.STRING, desc="报告类型 见底部表"),
169
+ ColumnInfo(name="comp_type", kind=ColumnKind.STRING, desc="公司类型(1一般工商业2银行3保险4证券)"),
170
+ ColumnInfo(name="end_type", kind=ColumnKind.STRING, desc="报告期类型"),
171
+ ColumnInfo(name="update_flag", kind=ColumnKind.STRING, desc="更新标识"),
172
+ ColumnInfo(name="basic_eps", kind=ColumnKind.FLOAT, desc="基本每股收益"),
173
+ ColumnInfo(name="diluted_eps", kind=ColumnKind.FLOAT, desc="稀释每股收益"),
174
+ ColumnInfo(name="total_revenue", kind=ColumnKind.FLOAT, desc="营业总收入"),
175
+ ColumnInfo(name="revenue", kind=ColumnKind.FLOAT, desc="营业收入"),
176
+ ColumnInfo(name="int_income", kind=ColumnKind.FLOAT, desc="利息收入"),
177
+ ColumnInfo(name="prem_earned", kind=ColumnKind.FLOAT, desc="已赚保费"),
178
+ ColumnInfo(name="comm_income", kind=ColumnKind.FLOAT, desc="手续费及佣金收入"),
179
+ ColumnInfo(name="n_commis_income", kind=ColumnKind.FLOAT, desc="手续费及佣金净收入"),
180
+ ColumnInfo(name="n_oth_income", kind=ColumnKind.FLOAT, desc="其他经营净收益"),
181
+ ColumnInfo(name="n_oth_b_income", kind=ColumnKind.FLOAT, desc="加:其他业务净收益"),
182
+ ColumnInfo(name="prem_income", kind=ColumnKind.FLOAT, desc="保险业务收入"),
183
+ ColumnInfo(name="out_prem", kind=ColumnKind.FLOAT, desc="减:分出保费"),
184
+ ColumnInfo(name="une_prem_reser", kind=ColumnKind.FLOAT, desc="提取未到期责任准备金"),
185
+ ColumnInfo(name="reins_income", kind=ColumnKind.FLOAT, desc="其中:分保费收入"),
186
+ ColumnInfo(name="n_sec_tb_income", kind=ColumnKind.FLOAT, desc="代理买卖证券业务净收入"),
187
+ ColumnInfo(name="n_sec_uw_income", kind=ColumnKind.FLOAT, desc="证券承销业务净收入"),
188
+ ColumnInfo(name="n_asset_mg_income", kind=ColumnKind.FLOAT, desc="受托客户资产管理业务净收入"),
189
+ ColumnInfo(name="oth_b_income", kind=ColumnKind.FLOAT, desc="其他业务收入"),
190
+ ColumnInfo(name="fv_value_chg_gain", kind=ColumnKind.FLOAT, desc="加:公允价值变动净收益"),
191
+ ColumnInfo(name="invest_income", kind=ColumnKind.FLOAT, desc="加:投资净收益"),
192
+ ColumnInfo(name="ass_invest_income", kind=ColumnKind.FLOAT, desc="其中:对联营企业和合营企业的投资收益"),
193
+ ColumnInfo(name="forex_gain", kind=ColumnKind.FLOAT, desc="加:汇兑净收益"),
194
+ ColumnInfo(name="total_cogs", kind=ColumnKind.FLOAT, desc="营业总成本"),
195
+ ColumnInfo(name="oper_cost", kind=ColumnKind.FLOAT, desc="减:营业成本"),
196
+ ColumnInfo(name="int_exp", kind=ColumnKind.FLOAT, desc="减:利息支出"),
197
+ ColumnInfo(name="comm_exp", kind=ColumnKind.FLOAT, desc="减:手续费及佣金支出"),
198
+ ColumnInfo(name="biz_tax_surchg", kind=ColumnKind.FLOAT, desc="减:营业税金及附加"),
199
+ ColumnInfo(name="sell_exp", kind=ColumnKind.FLOAT, desc="减:销售费用"),
200
+ ColumnInfo(name="admin_exp", kind=ColumnKind.FLOAT, desc="减:管理费用"),
201
+ ColumnInfo(name="fin_exp", kind=ColumnKind.FLOAT, desc="减:财务费用"),
202
+ ColumnInfo(name="assets_impair_loss", kind=ColumnKind.FLOAT, desc="减:资产减值损失"),
203
+ ColumnInfo(name="prem_refund", kind=ColumnKind.FLOAT, desc="退保金"),
204
+ ColumnInfo(name="compens_payout", kind=ColumnKind.FLOAT, desc="赔付总支出"),
205
+ ColumnInfo(name="reser_insur_liab", kind=ColumnKind.FLOAT, desc="提取保险责任准备金"),
206
+ ColumnInfo(name="div_payt", kind=ColumnKind.FLOAT, desc="保户红利支出"),
207
+ ColumnInfo(name="reins_exp", kind=ColumnKind.FLOAT, desc="分保费用"),
208
+ ColumnInfo(name="oper_exp", kind=ColumnKind.FLOAT, desc="营业支出"),
209
+ ColumnInfo(name="compens_payout_refu", kind=ColumnKind.FLOAT, desc="减:摊回赔付支出"),
210
+ ColumnInfo(name="insur_reser_refu", kind=ColumnKind.FLOAT, desc="减:摊回保险责任准备金"),
211
+ ColumnInfo(name="reins_cost_refund", kind=ColumnKind.FLOAT, desc="减:摊回分保费用"),
212
+ ColumnInfo(name="other_bus_cost", kind=ColumnKind.FLOAT, desc="其他业务成本"),
213
+ ColumnInfo(name="operate_profit", kind=ColumnKind.FLOAT, desc="营业利润"),
214
+ ColumnInfo(name="non_oper_income", kind=ColumnKind.FLOAT, desc="加:营业外收入"),
215
+ ColumnInfo(name="non_oper_exp", kind=ColumnKind.FLOAT, desc="减:营业外支出"),
216
+ ColumnInfo(name="nca_disploss", kind=ColumnKind.FLOAT, desc="其中:减:非流动资产处置净损失"),
217
+ ColumnInfo(name="total_profit", kind=ColumnKind.FLOAT, desc="利润总额"),
218
+ ColumnInfo(name="income_tax", kind=ColumnKind.FLOAT, desc="所得税费用"),
219
+ ColumnInfo(name="n_income", kind=ColumnKind.FLOAT, desc="净利润(含少数股东损益)"),
220
+ ColumnInfo(name="n_income_attr_p", kind=ColumnKind.FLOAT, desc="净利润(不含少数股东损益)"),
221
+ ColumnInfo(name="minority_gain", kind=ColumnKind.FLOAT, desc="少数股东损益"),
222
+ ColumnInfo(name="oth_compr_income", kind=ColumnKind.FLOAT, desc="其他综合收益"),
223
+ ColumnInfo(name="t_compr_income", kind=ColumnKind.FLOAT, desc="综合收益总额"),
224
+ ColumnInfo(name="compr_inc_attr_p", kind=ColumnKind.FLOAT, desc="归属于母公司(或股东)的综合收益总额"),
225
+ ColumnInfo(name="compr_inc_attr_m_s", kind=ColumnKind.FLOAT, desc="归属于少数股东的综合收益总额"),
226
+ ColumnInfo(name="ebit", kind=ColumnKind.FLOAT, desc="息税前利润"),
227
+ ColumnInfo(name="ebitda", kind=ColumnKind.FLOAT, desc="息税折旧摊销前利润"),
228
+ ColumnInfo(name="insurance_exp", kind=ColumnKind.FLOAT, desc="保险业务支出"),
229
+ ColumnInfo(name="undist_profit", kind=ColumnKind.FLOAT, desc="年初未分配利润"),
230
+ ColumnInfo(name="distable_profit", kind=ColumnKind.FLOAT, desc="可分配利润"),
231
+ ColumnInfo(name="rd_exp", kind=ColumnKind.FLOAT, desc="研发费用"),
232
+ ColumnInfo(name="fin_exp_int_exp", kind=ColumnKind.FLOAT, desc="财务费用:利息费用"),
233
+ ColumnInfo(name="fin_exp_int_inc", kind=ColumnKind.FLOAT, desc="财务费用:利息收入"),
234
+ ColumnInfo(name="transfer_surplus_rese", kind=ColumnKind.FLOAT, desc="盈余公积转入"),
235
+ ColumnInfo(name="transfer_housing_imprest", kind=ColumnKind.FLOAT, desc="住房周转金转入"),
236
+ ColumnInfo(name="transfer_oth", kind=ColumnKind.FLOAT, desc="其他转入"),
237
+ ColumnInfo(name="adj_lossgain", kind=ColumnKind.FLOAT, desc="调整以前年度损益"),
238
+ ColumnInfo(name="withdra_legal_surplus", kind=ColumnKind.FLOAT, desc="提取法定盈余公积"),
239
+ ColumnInfo(name="withdra_legal_pubfund", kind=ColumnKind.FLOAT, desc="提取法定公益金"),
240
+ ColumnInfo(name="withdra_biz_devfund", kind=ColumnKind.FLOAT, desc="提取企业发展基金"),
241
+ ColumnInfo(name="withdra_rese_fund", kind=ColumnKind.FLOAT, desc="提取储备基金"),
242
+ ColumnInfo(name="withdra_oth_ersu", kind=ColumnKind.FLOAT, desc="提取任意盈余公积金"),
243
+ ColumnInfo(name="workers_welfare", kind=ColumnKind.FLOAT, desc="职工奖金福利"),
244
+ ColumnInfo(name="distr_profit_shrhder", kind=ColumnKind.FLOAT, desc="可供股东分配的利润"),
245
+ ColumnInfo(name="prfshare_payable_dvd", kind=ColumnKind.FLOAT, desc="应付优先股股利"),
246
+ ColumnInfo(name="comshare_payable_dvd", kind=ColumnKind.FLOAT, desc="应付普通股股利"),
247
+ ColumnInfo(name="capit_comstock_div", kind=ColumnKind.FLOAT, desc="转作股本的普通股股利"),
248
+ ColumnInfo(name="net_after_nr_lp_correct", kind=ColumnKind.FLOAT, desc="扣除非经常性损益后的净利润(更正前)"),
249
+ ColumnInfo(name="credit_impa_loss", kind=ColumnKind.FLOAT, desc="信用减值损失"),
250
+ ColumnInfo(name="net_expo_hedging_benefits", kind=ColumnKind.FLOAT, desc="净敞口套期收益"),
251
+ ColumnInfo(name="oth_impair_loss_assets", kind=ColumnKind.FLOAT, desc="其他资产减值损失"),
252
+ ColumnInfo(name="total_opcost", kind=ColumnKind.FLOAT, desc="营业总成本(二)"),
253
+ ColumnInfo(name="amodcost_fin_assets", kind=ColumnKind.FLOAT, desc="以摊余成本计量的金融资产终止确认收益"),
254
+ ColumnInfo(name="oth_income", kind=ColumnKind.FLOAT, desc="其他收益"),
255
+ ColumnInfo(name="asset_disp_income", kind=ColumnKind.FLOAT, desc="资产处置收益"),
256
+ ColumnInfo(name="continued_net_profit", kind=ColumnKind.FLOAT, desc="持续经营净利润"),
257
+ ColumnInfo(name="end_net_profit", kind=ColumnKind.FLOAT, desc="终止经营净利润"),
258
+ ],
259
+ )