analyser_hj3415 2.1.0__py2.py3-none-any.whl → 2.2.0__py2.py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
@@ -7,6 +7,7 @@ from typing import Tuple
7
7
  from db_hj3415 import myredis, mymongo
8
8
  from analyser_hj3415.analysers import eval
9
9
  from utils_hj3415 import utils
10
+ from analyser_hj3415 import myredis as analyser_redis
10
11
 
11
12
  import logging
12
13
 
@@ -44,7 +45,7 @@ def red(code: str) -> int:
44
45
  recent_price = float('nan')
45
46
  return 0
46
47
 
47
- red_price = eval.red(code)['red_price']
48
+ red_price = analyser_redis.red(code)['red_price']
48
49
  deviation = cal_deviation(recent_price, red_price)
49
50
  if red_price < 0 or (recent_price >= red_price):
50
51
  score = 0
@@ -85,7 +86,7 @@ def mil(code: str) -> Tuple[int, int, int, int]:
85
86
  Returns:
86
87
  tuple: 주주수익률, 이익지표, 투자수익률, PFCF포인트
87
88
  """
88
- mil_dict = eval.mil(code)
89
+ mil_dict = analyser_redis.mil(code)
89
90
 
90
91
  print(pprint.pformat(mil_dict, width=200))
91
92
 
@@ -178,7 +179,7 @@ def blue(code: str) -> Tuple[int, int, int, int, int]:
178
179
 
179
180
  c104y = myredis.C104(code, 'c104y')
180
181
 
181
- blue_dict = eval.blue(code)
182
+ blue_dict = analyser_redis.blue(code)
182
183
 
183
184
  print(pprint.pformat(blue_dict, width=200))
184
185
 
@@ -275,7 +276,7 @@ def growth(code: str) -> Tuple[int, int]:
275
276
  Returns:
276
277
  tuple : 매출액증가율, 영업이익률 평가 포인트
277
278
  """
278
- growth_dict = eval.growth(code)
279
+ growth_dict = analyser_redis.growth(code)
279
280
 
280
281
  logger.debug(pprint.pformat(growth_dict, width=200))
281
282
 
@@ -0,0 +1,175 @@
1
+ from analyser_hj3415.analysers import eval
2
+ from db_hj3415.myredis import Base
3
+ import json
4
+
5
+ page = '.analyser'
6
+
7
+
8
+ def red(code: str) -> dict:
9
+ """
10
+ redis 사용 - 소멸타이머 사용
11
+ 리턴값
12
+ {
13
+ 'red_price': red_price,
14
+ '사업가치': 사업가치,
15
+ '재산가치': 재산가치,
16
+ '부채평가': 부채평가,
17
+ '발행주식수': 발행주식수,
18
+ 'date': [각 유효한 값의 년월값 리스트(ex- 2020/09)],
19
+ }
20
+ """
21
+ redis_name = code + page + '_eval_' + 'red'
22
+ try:
23
+ cached_data = Base.redis_client.get(redis_name).decode('utf-8')
24
+ except AttributeError:
25
+ # redis에 해당하는 값이 없는 경우
26
+ data = eval.red(code)
27
+ # print(data)
28
+ if data:
29
+ # 데이터를 Redis에 캐싱
30
+ Base.redis_client.set(redis_name, json.dumps(data))
31
+ # 60분후 키가 자동으로 제거됨
32
+ Base.redis_client.expire(redis_name, 3600)
33
+ print("analysers.eval 데이터 계산하기 - myredis.red")
34
+ return data
35
+ else:
36
+ print(f"Redis 캐시에서 데이터 가져오기(남은시간:{Base.redis_client.ttl(redis_name)}초) - myredis.red")
37
+ return json.loads(cached_data)
38
+
39
+
40
+ def mil(code: str) -> dict:
41
+ """
42
+ redis 사용 - 소멸타이머 사용
43
+ 리턴값
44
+ {
45
+ '주주수익률': 주주수익률,
46
+ '이익지표': 이익지표,
47
+ '투자수익률': {'ROIC': roic, 'ROE': roe , 'ROE106': {}},
48
+ '가치지표': {'FCF': fcf_dict, 'PFCF': pfcf_dict, 'PCR': pcr_dict},
49
+ 'date': [각 유효한 값의 년월값 리스트(ex- 2020/09)],
50
+ }
51
+
52
+ - 재무활동현금흐름이 마이너스라는 것은 배당급 지급했거나, 자사주 매입했거나, 부채를 상환한 상태임.
53
+ - 반대는 채권자로 자금을 조달했거나 신주를 발행했다는 의미
54
+ <주주수익률> - 재무활동현금흐름/시가총액 => 5%이상인가?
55
+
56
+ 투하자본수익률(ROIC)가 30%이상인가
57
+ ROE(자기자본이익률) 20%이상이면 아주 우수 다른 투자이익률과 비교해볼것 10%미만이면 별로...단, 부채비율을 확인해야함.
58
+
59
+ 이익지표 ...영업현금흐름이 순이익보다 많은가 - 결과값이 음수인가..
60
+
61
+ FCF는 영업현금흐름에서 자본적 지출(유·무형투자 비용)을 차감한 순수한 현금력이라 할 수 있다.
62
+ 말 그대로 자유롭게(Free) 사용할 수 있는 여윳돈을 뜻한다.
63
+ 잉여현금흐름이 플러스라면 미래의 투자나 채무상환에 쓸 재원이 늘어난 것이다.
64
+ CAPEX(Capital expenditures)는 미래의 이윤을 창출하기 위해 지출된 비용을 말한다.
65
+ 이는 기업이 고정자산을 구매하거나, 유효수명이 당회계년도를 초과하는 기존의 고정자산에 대한 투자에 돈이 사용될 때 발생한다.
66
+
67
+ 잉여현금흐름이 마이너스일때는 설비투자가 많은 시기라 주가가 약세이며 이후 설비투자 마무리되면서 주가가 상승할수 있다.
68
+ 주가는 잉여현금흐름이 증가할때 상승하는 경향이 있다.
69
+ fcf = 영업현금흐름 - capex
70
+
71
+ 가치지표평가
72
+ price to fcf 계산
73
+ https://www.investopedia.com/terms/p/pricetofreecashflow.asp
74
+ pcr보다 정확하게 주식의 가치를 평가할수 있음. 10배이하 추천
75
+ """
76
+ redis_name = code + page + '_eval_' + 'mil'
77
+ try:
78
+ cached_data = Base.redis_client.get(redis_name).decode('utf-8')
79
+ except AttributeError:
80
+ # redis에 해당하는 값이 없는 경우
81
+ data = eval.mil(code)
82
+ # print(data)
83
+ if data:
84
+ # 데이터를 Redis에 캐싱
85
+ Base.redis_client.set(redis_name, json.dumps(data))
86
+ # 60분후 키가 자동으로 제거됨
87
+ Base.redis_client.expire(redis_name, 3600)
88
+ print("analysers.eval 데이터 계산하기 - myredis.mil")
89
+ return data
90
+ else:
91
+ print(f"Redis 캐시에서 데이터 가져오기(남은시간:{Base.redis_client.ttl(redis_name)}초) - myredis.mil")
92
+ return json.loads(cached_data)
93
+
94
+
95
+ def blue(code: str) -> dict:
96
+ """
97
+ redis 사용 - 소멸타이머 사용
98
+ 리턴값
99
+ {
100
+ 'date': [각 유효한 값의 최근분기 값 리스트(ex- 2020/09)],
101
+ '순부채비율': (29.99, {'2018/12': 19.45, '2019/12': 19.52, '2020/12': 12.07, '2021/12': 82.2, '2022/12': 29.99, '2023/12': nan}),
102
+ '순운전자본회전율': (1.04, {'2018/12': 21.91, '2019/12': 23.12, '2020/12': 5.88, '2021/12': 5.6, '2022/12': 6.04, '2023/12': nan}),
103
+ '유동비율': 64.29,
104
+ '이자보상배율': (-3.64, {'2018/12': 4.01, '2019/12': 1.3, '2020/12': -5.05, '2021/12': 0.56, '2022/12': -1.28, '2023/12': nan}),
105
+ '재고자산회전율': (1.66, {'2018/12': 12.41, '2019/12': 12.44, '2020/12': 9.18, '2021/12': 9.76, '2022/12': 8.79, '2023/12': nan})
106
+ }
107
+
108
+ <유동비율>
109
+ 100미만이면 주의하나 현금흐름창출력이 좋으면 괜찮을수 있다.
110
+ 만약 100%이하면 유동자산에 추정영업현금흐름을 더해서 다시계산해보아 기회를 준다.
111
+ <이자보상배율>
112
+ 이자보상배율 영업이익/이자비용으로 1이면 자금사정빡빡 5이상이면 양호
113
+ <순운전자금회전율>
114
+ 순운전자금 => 기업활동을 하기 위해 필요한 자금 (매출채권 + 재고자산 - 매입채무)
115
+ 순운전자본회전율은 매출액/순운전자본으로 일정비율이 유지되는것이 좋으며 너무 작아지면 순운전자본이 많아졌다는 의미로 재고나 외상이 쌓인다는 뜻
116
+ <재고자산회전율>
117
+ 재고자산회전율은 매출액/재고자산으로 회전율이 낮을수록 재고가 많다는 이야기이므로 불리 전년도등과 비교해서 큰차이 발생하면 알람.
118
+ 재고자산회전율이 작아지면 재고가 쌓인다는뜻
119
+ <순부채비율>
120
+ 부채비율은 업종마다 달라 일괄비교 어려우나 순부채 비율이 20%이하인것이 좋고 꾸준히 늘어나지 않는것이 좋다.
121
+ 순부채 비율이 30%이상이면 좋치 않다.
122
+ <매출액>
123
+ 매출액은 어떤경우에도 성장하는 기업이 좋다.매출이 20%씩 늘어나는 종목은 유망한 종목
124
+ <영업이익률>
125
+ 영업이익률은 기업의 경쟁력척도로 경쟁사에 비해 높으면 경제적해자를 갖춘셈
126
+ """
127
+ redis_name = code + page + '_eval_' + 'blue'
128
+ try:
129
+ cached_data = Base.redis_client.get(redis_name).decode('utf-8')
130
+ except AttributeError:
131
+ # redis에 해당하는 값이 없는 경우
132
+ data = eval.blue(code)
133
+ # print(data)
134
+ if data:
135
+ # 데이터를 Redis에 캐싱
136
+ Base.redis_client.set(redis_name, json.dumps(data))
137
+ # 60분후 키가 자동으로 제거됨
138
+ Base.redis_client.expire(redis_name, 3600)
139
+ print("analysers.eval 데이터 계산하기 - myredis.blue")
140
+ return data
141
+ else:
142
+ print(f"Redis 캐시에서 데이터 가져오기(남은시간:{Base.redis_client.ttl(redis_name)}초) - myredis.blue")
143
+ return json.loads(cached_data)
144
+
145
+
146
+ def growth(code: str) -> dict:
147
+ """
148
+ redis 사용 - 소멸타이머 사용
149
+ 리턴값
150
+ {'date': [각 유효한 값의 최근분기 값 리스트(ex- 2020/09)],
151
+ '매출액증가율': (-14.37, {'2018/12': -24.56, '2019/12': -20.19, '2020/12': -12.64, '2021/12': 38.65, '2022/12': -8.56, '2023/12': nan}),
152
+ '영업이익률': {'뉴프렉스': '17.36', '동일기연': '13.58', '비에이치': '16.23', '에이엔피': '-9.30', '이브이첨단소재': '-4.93'}}
153
+
154
+ <매출액>
155
+ 매출액은 어떤경우에도 성장하는 기업이 좋다.매출이 20%씩 늘어나는 종목은 유망한 종목
156
+ <영업이익률>
157
+ 영업이익률은 기업의 경쟁력척도로 경쟁사에 비해 높으면 경제적해자를 갖춘셈
158
+ """
159
+ redis_name = code + page + '_eval_' + 'growth'
160
+ try:
161
+ cached_data = Base.redis_client.get(redis_name).decode('utf-8')
162
+ except AttributeError:
163
+ # redis에 해당하는 값이 없는 경우
164
+ data = eval.growth(code)
165
+ # print(data)
166
+ if data:
167
+ # 데이터를 Redis에 캐싱
168
+ Base.redis_client.set(redis_name, json.dumps(data))
169
+ # 60분후 키가 자동으로 제거됨
170
+ Base.redis_client.expire(redis_name, 3600)
171
+ print("analysers.eval 데이터 계산하기 - myredis.growth")
172
+ return data
173
+ else:
174
+ print(f"Redis 캐시에서 데이터 가져오기(남은시간:{Base.redis_client.ttl(redis_name)}초) - myredis.growth")
175
+ return json.loads(cached_data)
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: analyser_hj3415
3
- Version: 2.1.0
3
+ Version: 2.2.0
4
4
  Summary: Stock analyser and database processing programs
5
5
  Author-email: Hyungjin Kim <hj3415@gmail.com>
6
6
  Description-Content-Type: text/markdown
@@ -1,14 +1,15 @@
1
1
  analyser_hj3415/.DS_Store,sha256=OQfTSOHL-zjUtnNyBpNRVUJUstR4j6I7jihKDFQQmME,6148
2
2
  analyser_hj3415/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
3
3
  analyser_hj3415/cli.py,sha256=qzRnpDRJvQnQevSKHBpKbTsBjmSWllZjzTV4z_alg2A,4891
4
+ analyser_hj3415/myredis.py,sha256=zgsXO4G2VsXt4LID4VF-Y7AqkPjV8Th66a2czuma_bM,8738
4
5
  analyser_hj3415/run.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
6
  analyser_hj3415/tools.py,sha256=SNsrnL5CKmKAdFkmlwgREMIkWDRi6N9LngCdhhhop3Y,13606
6
7
  analyser_hj3415/trash.py,sha256=vHrv8Q61QOkcwhmWfrj_yVdsdd5MoAxs9gXMOJEjMHM,8360
7
8
  analyser_hj3415/analysers/eval.py,sha256=mlHi6EPc8l8O6vKnWyX4Cz1BaeGhUpWM8gVZRNhm-JU,13299
8
9
  analyser_hj3415/analysers/report.py,sha256=whggmLXl7yF-BjQ6JKgxmhILT2T4uFP-rit_BSes9xM,9189
9
- analyser_hj3415/analysers/score.py,sha256=DoLac-PXQrA-GfkEHRD52R-8FFJD-eYLCPTg3oEkNGA,16213
10
- analyser_hj3415-2.1.0.dist-info/entry_points.txt,sha256=dHaCM3eOAGONmxTWuRVqo9Zyq2C7J5TZmpH0PD6FW5k,103
11
- analyser_hj3415-2.1.0.dist-info/LICENSE,sha256=QVKTp0dTnB5xG8RLgG17LwSWCKNEzYoVVM6KjoCPKc0,1079
12
- analyser_hj3415-2.1.0.dist-info/WHEEL,sha256=Sgu64hAMa6g5FdzHxXv9Xdse9yxpGGMeagVtPMWpJQY,99
13
- analyser_hj3415-2.1.0.dist-info/METADATA,sha256=h7E4uyJhGWiRAOVfZ-ApChWxDfm8pOi8Iu-iz1Byqpg,6417
14
- analyser_hj3415-2.1.0.dist-info/RECORD,,
10
+ analyser_hj3415/analysers/score.py,sha256=C_Xiqo44o2OAXHaHiHYLa60HwKwpUt_H18uO5Iff1TM,16308
11
+ analyser_hj3415-2.2.0.dist-info/entry_points.txt,sha256=dHaCM3eOAGONmxTWuRVqo9Zyq2C7J5TZmpH0PD6FW5k,103
12
+ analyser_hj3415-2.2.0.dist-info/LICENSE,sha256=QVKTp0dTnB5xG8RLgG17LwSWCKNEzYoVVM6KjoCPKc0,1079
13
+ analyser_hj3415-2.2.0.dist-info/WHEEL,sha256=Sgu64hAMa6g5FdzHxXv9Xdse9yxpGGMeagVtPMWpJQY,99
14
+ analyser_hj3415-2.2.0.dist-info/METADATA,sha256=OJhj-1acjb5Ht817i0tzqYdLUkA94NpGVZ-dclMstKo,6417
15
+ analyser_hj3415-2.2.0.dist-info/RECORD,,