db2_hj3415 0.1.10__py2.py3-none-any.whl → 0.1.11__py2.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.
db2_hj3415/nfs/c108.py CHANGED
@@ -1,4 +1,6 @@
1
1
  from motor.motor_asyncio import AsyncIOMotorClient
2
+ from typing import Any
3
+ import math
2
4
  from pymongo import ASCENDING, UpdateOne, DESCENDING
3
5
  import pandas as pd
4
6
  from datetime import datetime, timezone, timedelta
@@ -12,36 +14,43 @@ mylogger = setup_logger(__name__, 'WARNING')
12
14
  COL_NAME = 'c108'
13
15
 
14
16
 
15
- async def save(code: str, data: pd.DataFrame, client: AsyncIOMotorClient) -> dict:
17
+ async def save(code: str, data: pd.DataFrame, client, db_name: str = DB_NAME, col_name: str = COL_NAME) -> dict:
16
18
  if data is None or data.empty:
17
19
  print("데이터 없음 - 저장 생략")
18
20
  return {"status": "unchanged"}
19
21
 
20
- collection = get_collection(client, DB_NAME, COL_NAME)
22
+ collection = get_collection(client, db_name, col_name)
21
23
 
22
24
  await collection.create_index(
23
25
  [("코드", ASCENDING), ("날짜", ASCENDING), ("제목", ASCENDING)],
24
26
  unique=True
25
27
  )
26
28
 
27
- # NaN -> None 변환
28
- df = data.where(pd.notnull(data), None)
29
+ def convert_nan_to_none(x: Any) -> Any:
30
+ if isinstance(x, float) and (math.isnan(x) or math.isinf(x)):
31
+ return None
32
+ return x
33
+
34
+ # DataFrame의 각 열에 대해 map 적용 (applymap 대체)
35
+ df = data.apply(lambda col: col.map(convert_nan_to_none))
36
+
29
37
  operations = []
30
- inserted, updated, skipped = 0, 0, 0
38
+ inserted, updated = 0, 0
31
39
 
32
40
  for _, row in df.iterrows():
33
41
  try:
34
- date_str = str(row["날짜"])
42
+ doc = row.to_dict()
43
+
44
+ date_str = str(doc["날짜"])
35
45
  date_obj = datetime.strptime(date_str, DATE_FORMAT).replace(tzinfo=timezone.utc)
36
46
 
37
- doc = row.to_dict()
38
47
  doc["코드"] = code
39
48
  doc["날짜"] = date_obj
40
49
 
41
- filter_ = {"코드": code, "날짜": date_obj, "제목": doc["제목"]}
50
+ filter_ = {"코드": code, "날짜": date_obj, "제목": doc.get("제목")}
42
51
  operations.append(UpdateOne(filter_, {"$set": doc}, upsert=True))
43
52
  except Exception as e:
44
- print(f"변환 에러 - {row.get('제목', '제목 없음')}: {e}")
53
+ print(f"[{code}] 변환 에러 - {doc.get('제목', '제목 없음')}: {e}")
45
54
  continue
46
55
 
47
56
  if operations:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: db2_hj3415
3
- Version: 0.1.10
3
+ Version: 0.1.11
4
4
  Summary: Gathering the stock data by playwright
5
5
  Author-email: Hyungjin Kim <hj3415@gmail.com>
6
6
  Description-Content-Type: text/markdown
@@ -25,7 +25,7 @@ db2_hj3415/nfs/c101.py,sha256=5gndh6OAQPHc6cvBBnBqdfHuMt34oEoFaXFOdCRv62I,5077
25
25
  db2_hj3415/nfs/c103.py,sha256=HfbknyRcC7-mKF5vnZzlHnESl9fBRwoIEZ_WCy6-tsM,1864
26
26
  db2_hj3415/nfs/c104.py,sha256=yYV2dxble1pXx4f_X7q6bKY54WDHgJ3btTbvX0C3Mik,1864
27
27
  db2_hj3415/nfs/c106.py,sha256=lzbMROOQ-w1AU8oeSYsYFhYuk0EuOux97CKuJrWhx1A,1864
28
- db2_hj3415/nfs/c108.py,sha256=WvT7Fs-BOd0nm_aZGWI4g8Kyo-fFu1dUP7QYyTL87tk,3761
28
+ db2_hj3415/nfs/c108.py,sha256=LAEe_3jWlHeYkm1NnsemzmetOIw2mPLOx-XHQEBzZ9Y,4044
29
29
  db2_hj3415/nfs/dart.py,sha256=vVDP2ee5akaoR_m17eN4PxVxxfg5K77TLxVXzQ9ZLyU,3392
30
30
  db2_hj3415/nfs/models.py,sha256=Y5FgSiB_BPzX5hY8RLWAFSXCl22LTECTi6RJAtXbaMU,5005
31
31
  db2_hj3415/valuation/__init__.py,sha256=SxzWnyeo412A6q7yqYHtQz0Qv-haoAN6qr5Q4h2NRqw,274
@@ -35,7 +35,7 @@ db2_hj3415/valuation/growth.py,sha256=bpixczYpGx6cfb2ChsZXM8YkNDrHMaNWdkuMyPZuld
35
35
  db2_hj3415/valuation/mil.py,sha256=kOc9MYrzHYTL7oBSOI95gTD2Edu3H2yOd3R-0qdaH8c,480
36
36
  db2_hj3415/valuation/models.py,sha256=fBmWhtdUE56E7AaFs-04aw4WC8ptm-Thl_IX7Yex0js,5592
37
37
  db2_hj3415/valuation/red.py,sha256=YV3uavn0A6-T5fk5YiD5MdpC2XhjZMN1mP-e2n_VJrs,481
38
- db2_hj3415-0.1.10.dist-info/entry_points.txt,sha256=JAGFsxKtvbNgaKCSKo-QRYwCyToabWmdRW0MZWtg9kg,45
39
- db2_hj3415-0.1.10.dist-info/WHEEL,sha256=Dyt6SBfaasWElUrURkknVFAZDHSTwxg3PaTza7RSbkY,100
40
- db2_hj3415-0.1.10.dist-info/METADATA,sha256=nTnOhMzON77D0gN7YMDOSOE4SVAqa1BgV8X3AuRUTiE,689
41
- db2_hj3415-0.1.10.dist-info/RECORD,,
38
+ db2_hj3415-0.1.11.dist-info/entry_points.txt,sha256=JAGFsxKtvbNgaKCSKo-QRYwCyToabWmdRW0MZWtg9kg,45
39
+ db2_hj3415-0.1.11.dist-info/WHEEL,sha256=Dyt6SBfaasWElUrURkknVFAZDHSTwxg3PaTza7RSbkY,100
40
+ db2_hj3415-0.1.11.dist-info/METADATA,sha256=4rwJI8JL0c0RDEvkfUHKf16rcgfA7ps1hWVS5nq8vpg,689
41
+ db2_hj3415-0.1.11.dist-info/RECORD,,