reportify-sdk 0.2.6__tar.gz → 0.2.8__tar.gz

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.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: reportify-sdk
3
- Version: 0.2.6
3
+ Version: 0.2.8
4
4
  Summary: Python SDK for Reportify API - Financial data and document search
5
5
  Author-email: Reportify <support@reportify.cn>
6
6
  License-Expression: MIT
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "reportify-sdk"
7
- version = "0.2.6"
7
+ version = "0.2.8"
8
8
  description = "Python SDK for Reportify API - Financial data and document search"
9
9
  readme = "README.md"
10
10
  license = "MIT"
@@ -62,13 +62,14 @@ class Reportify:
62
62
  self._docs = None
63
63
  self._tools = None
64
64
  self._quant = None
65
+ self._concepts = None
65
66
 
66
67
  def _get_headers(self) -> dict[str, str]:
67
68
  """Get default headers for API requests"""
68
69
  return {
69
70
  "Authorization": f"Bearer {self.api_key}",
70
71
  "Content-Type": "application/json",
71
- "User-Agent": "reportify-sdk-python/0.1.0",
72
+ "User-Agent": "reportify-sdk-python/0.2.8",
72
73
  }
73
74
 
74
75
  def _request(
@@ -360,6 +361,14 @@ class Reportify:
360
361
  self._quant = QuantModule(self)
361
362
  return self._quant
362
363
 
364
+ @property
365
+ def concepts(self):
366
+ """Concepts module for accessing concept data and feeds"""
367
+ if self._concepts is None:
368
+ from reportify_sdk.concepts import ConceptsModule
369
+ self._concepts = ConceptsModule(self)
370
+ return self._concepts
371
+
363
372
  def close(self):
364
373
  """Close the HTTP client"""
365
374
  self._client.close()
@@ -0,0 +1,64 @@
1
+ """
2
+ Concepts Module
3
+
4
+ Provides access to concept-related data and feeds.
5
+ """
6
+
7
+ from typing import Any
8
+
9
+ from reportify_sdk.client import Reportify
10
+
11
+
12
+ class ConceptsModule:
13
+ """
14
+ Concepts module for accessing concept data and feeds
15
+
16
+ This module provides methods to:
17
+ - Get latest concepts
18
+ - Get today's concept feeds
19
+ """
20
+
21
+ def __init__(self, client: Reportify):
22
+ self.client = client
23
+
24
+ def _get(self, path: str, params: dict[str, Any] | None = None) -> dict[str, Any]:
25
+ """Helper method for GET requests"""
26
+ return self.client._get(path, params)
27
+
28
+ def latest(self, include_docs: bool = True) -> list[dict[str, Any]]:
29
+ """
30
+ Get latest concepts
31
+
32
+ Args:
33
+ include_docs: Whether to include related documents (default: True)
34
+
35
+ Returns:
36
+ List of latest concepts with stocks, keywords, and events
37
+
38
+ Example:
39
+ >>> # Get latest concepts
40
+ >>> concepts = client.concepts.latest()
41
+ >>> for concept in concepts:
42
+ ... print(concept['concept_name'])
43
+
44
+ >>> # Get concepts without documents
45
+ >>> concepts = client.concepts.latest(include_docs=False)
46
+ """
47
+ params = {"include_docs": include_docs}
48
+ return self._get("/v1/concepts/latest", params)
49
+
50
+ def today(self) -> list[dict[str, Any]]:
51
+ """
52
+ Get today's concept feeds
53
+
54
+ Returns:
55
+ List of today's concept feeds with events, stocks, and docs
56
+
57
+ Example:
58
+ >>> # Get today's concept feeds
59
+ >>> feeds = client.concepts.today()
60
+ >>> for feed in feeds:
61
+ ... print(f"{feed['concept_name']}: {feed['gen_count']} generations")
62
+ ... print(f"Time range: {feed['earliest_at']} - {feed['latest_at']}")
63
+ """
64
+ return self._get("/v1/concepts/today")
@@ -32,21 +32,44 @@ class StockModule:
32
32
  # Company Information
33
33
  # -------------------------------------------------------------------------
34
34
 
35
- def overview(self, symbol: str) -> dict[str, Any]:
35
+ def overview(
36
+ self, symbols: str | None = None, names: str | None = None
37
+ ) -> dict[str, Any] | list[dict[str, Any]]:
36
38
  """
37
39
  Get company overview including business description, sector, and key metrics
38
40
 
39
41
  Args:
40
- symbol: Stock symbol (e.g., "US:AAPL", "HK:0700", "CN:600519")
42
+ symbols: Stock symbols. You can enter multiple items, separated by commas(,)
43
+ Example: "US:AAPL,US:MSFT"
44
+ names: Stock names. You can enter multiple items, separated by commas(,)
45
+ Example: "Apple Inc.,Microsoft"
41
46
 
42
47
  Returns:
43
- Company information dictionary
48
+ Dictionary or list of dictionaries with company overview data
44
49
 
45
50
  Example:
46
- >>> info = client.stock.overview("US:AAPL")
51
+ >>> # Single stock by symbol
52
+ >>> info = client.stock.overview(symbols="US:AAPL")
47
53
  >>> print(info["name"], info["sector"])
54
+
55
+ >>> # Multiple stocks by symbols
56
+ >>> infos = client.stock.overview(symbols="US:AAPL,US:MSFT")
57
+ >>> for info in infos:
58
+ ... print(info["name"])
59
+
60
+ >>> # Search by name
61
+ >>> info = client.stock.overview(names="Apple Inc.")
48
62
  """
49
- response = self._post("/v1/stock/company-overview", json={"symbol": symbol})
63
+ if not symbols and not names:
64
+ raise ValueError("Either symbols or names must be provided")
65
+
66
+ data = {}
67
+ if symbols:
68
+ data["symbols"] = symbols
69
+ if names:
70
+ data["names"] = names
71
+
72
+ response = self._post("/v1/stock/company-overview", json=data)
50
73
  return response
51
74
 
52
75
  def shareholders(self, symbol: str) -> list[dict[str, Any]]:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: reportify-sdk
3
- Version: 0.2.6
3
+ Version: 0.2.8
4
4
  Summary: Python SDK for Reportify API - Financial data and document search
5
5
  Author-email: Reportify <support@reportify.cn>
6
6
  License-Expression: MIT
@@ -3,6 +3,7 @@ README.md
3
3
  pyproject.toml
4
4
  reportify_sdk/__init__.py
5
5
  reportify_sdk/client.py
6
+ reportify_sdk/concepts.py
6
7
  reportify_sdk/docs.py
7
8
  reportify_sdk/exceptions.py
8
9
  reportify_sdk/kb.py
File without changes
File without changes
File without changes