soju06 / python-kis Goto Github PK
View Code? Open in Web Editor NEW๐ ํ์ด์ฌ ํ๊ตญํฌ์์ฆ๊ถ REST ๊ธฐ๋ฐ Trading API ๋ผ์ด๋ธ๋ฌ๋ฆฌ
License: MIT License
๐ ํ์ด์ฌ ํ๊ตญํฌ์์ฆ๊ถ REST ๊ธฐ๋ฐ Trading API ๋ผ์ด๋ธ๋ฌ๋ฆฌ
License: MIT License
error from callback <bound method KisRTClient._onclose of <Pykis._pykis.rtclient.rtclient.KisRTClient object at 0x7f1558ba72d0>>: KisRTClient._onclose() takes 2 positional arguments but 4 were given
realtime = True (default)์ผ๋ ๊ฐํน ์ ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค. ์์ธ์ ์ ์ ์์๊น์?
์์
์งํ์ ์ํฅ์ ๋ผ์น์ ์ ์์ง๋ง ์ ์ด์๋ก ๋ฐ์ ํ์๋๋ ์ถ๊ฐ์ ์ธ ์ด์์ ๊ฐ๋ฅ์ฑ์ด ์์๊น์?
[๋ฌธ์ฅ์ ์ง์ฐ๊ณ , ๋ฒ๊ทธ๊ฐ ๋ฐ์ํ ์ฝ๋๋ ์ค๋ช ์ ์์ฑํฉ๋๋ค.]
[์์ธ์ ๋ชจ๋ฅธ๋ค๋ฉด ๋น์นธ์ผ๋ก ์ ๋ ฅํฉ๋๋ค.]
ํ์ด์ฌ ๋ฒ์ : ?
[๊ท์ฐฎ์ผ์๋ฉด ์ ์จ๋ ๋ผ์...]
์ด๋ฆ | ๋ฒ์ |
---|---|
requests | ? |
SQLAlchemy | ? |
websocket-client | ? |
pycryptodome | ? |
colorlog | ? |
์๋
ํ์ธ์. ์ฅ์ด ์ด๋ฆฌ๊ธฐ ์ ์ ์ฃผ๋ฌธ์ ๋ฏธ๋ฆฌ ๋ฃ์ผ๋ ค๊ณ ํฉ๋๋ค.
์ด๋ฌํ ๊ธฐ๋ฅ์ด ์์๊น์?
๊ฐ์ฌํฉ๋๋ค.
๊น์งํ ๋๋ฆผ
ํด์ธ์ฃผ์ ๋งค์์์๋ ์๋ฌ๊ฐ ๋ฐ์ํ์ง ์์ผ๋ ๋งค๋์์๋ ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค.
๋์ค๋ฅ ๋งค๋์ฃผ๋ฌธ์ ์คํํ๋ฉด ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค.
order1 = account.overseas_sell(
market="๋์ค๋ฅ",
code="TSLA",
qty=3,
unpr=240
)
print(order1.message)
๋ชจ์ ํฌ์์ TR_ID_CODE_MAP์ ์๋ TR_ID ๊ฐ ์๋ชป๋์ด ์์ต๋๋ค.
overseas_order.py ์ 18ํ - 20ํ์
๋๋ค.
+++++++++++++๋ฐ์ทจ+++++++++++++
'NASD': ('VTTT1002U', 'VTTT1006U'), # ๋ฏธ๊ตญ
'NYSE': ('VTTT1002U', 'VTTT1006U'), # ๋ฏธ๊ตญ
'AMEX': ('VTTT1002U', 'VTTT1006U'), # ๋ฏธ๊ตญ
+++++++++++++++++++++++++++++
VTTT1006U -> VTTT1001U ์ด๊ฒ ๋ง์ต๋๋ค.
๊ทธ๋ฆฌ๊ณ 67ํ์ ์๋ OVERSEAS_ORD_DVSN_MAP ์์ ์๋ฌ๊ฐ ๋ฐ์ํ๋๋ฐ VTTT1001U๋ฅผ ์ถ๊ฐํ๋ฉด ์๋ฌ๊ฐ ์๋ฉ๋๋ค.
์) 'VTTT1001U': {'00', '์ง์ ๊ฐ'},
์์ ๋ถํํฉ๋๋ค.
ํ์ด์ฌ ๋ฒ์ : 3.11
[๊ท์ฐฎ์ผ์๋ฉด ์ ์จ๋ ๋ผ์...]
์ด๋ฆ | ๋ฒ์ |
---|---|
requests | ? |
SQLAlchemy | ? |
websocket-client | ? |
pycryptodome | ? |
colorlog | ? |
์๋
ํ์ธ์. ๋ชจ์๊ณ์ข๋ฅผ ํฌํจํด์ 5๊ฐ ์ ๋์ ๊ณ์ ์ ํ๋์ process์์ ๋๋ ค๋ณด์๋๋ฐ,
๋ฉ๋ชจ๋ฆฌ ๋์ ํ์์ด ๋ํ๋ฌ๊ณ , ์์ธ์ ํ์
ํด๋ณด๋ thread๊ฐ ์ง์์ ์ผ๋ก ์์ฑ๋๋ ๊ฒ์ ํ์ธํ์ต๋๋ค.
์๋ง๋ ์บ์ฑํ ์ข ๋ชฉ ์ ๋ณด๋ค์ ์ ๋ฐ์ดํธํ๋ ๊ณผ์ ์์ ๋ฐ์ํ๋ ๊ฒ ๊ฐ์๋ฐ,
Q1. ํน์ ์ ๊ฐ ์ฝ๋๋ฅผ ์งง์ ์๊ฐ ๋์ ํ์ ํ๊ณ ๋ง๋ ์๋ฃจ์ ์ด ๋ง์์ง ์ฌ์ญค๋ณด๊ณ ์ถ์ต๋๋ค.
๋ง๋ค์ด์ฃผ์ ํจํค์ง ์์ฐ๊ณ ์์ต๋๋ค.
์ ๊ฐ ์ฃผ๊ธฐ์ ์ผ๋ก ์ฃผ๊ฐ๋ฅผ ์ฒดํฌํ๋๋ฐ, ์ด๊ฒ PyKis๋ฅผ ์์ฑํ ๋๋ง๋ค ์๋ก token์ด ๋ง๋ค์ด์ง๊ณ ์ด๊ฒ ๋๋ฌธ์ ์นด์นด์คํก์ด ๊ทธ ๋๋ง๋ค ๋ ์์ค๋ค์. ์์ฑ์ token expires_in์ ์ค์ ํ๋ ๋ฐฉ๋ฒ์ด ์์๊น์? ์๋๋ฉด PyKis object๋ฅผ pickle/redis๋ก ์บ์ฑํด์ ์ฐ๋ ๊ฒ์ด ๊ฐ๋ฅํ ๊น์?
์๋
ํ์ธ์. ์ฅ์ด ์ด๋ฆฌ๊ธฐ ์ ์ ์ฃผ๋ฌธ์ ๋ฏธ๋ฆฌ ๋ฃ์ผ๋ ค๊ณ ํฉ๋๋ค.
์ด๋ฌํ ๊ธฐ๋ฅ์ด ์์๊น์?
๊ฐ์ฌํฉ๋๋ค.
๊น์งํ ๋๋ฆผ
์๋
ํ์ธ์. ๊ฐ๋ฐ์๋
์ข
๋ชฉ ์ ๋ณด ์๋ ๋๊ธฐํ ์ฌ๋ถ(market_auto_sync)๋ฅผ False๋ก ํ์๋ ์คํ์๋๊ฐ ๋น ๋ฅธ๊ฑฐ ๊ฐ์ False๋ก ์ค์ ํ๋ ค๊ณ ํฉ๋๋ค.
ํน์ False๋ก ํด๋ ๋ฌธ์ ๊ฐ ์์๊น์?
๋ง์ฝ False๋ก ํ์๋ ์ด๋ค๋ฌธ์ ๊ฐ ๋ฐ์ํ ์ง ์กฐ์ธ ๋ถํ๋๋ฆฝ๋๋ค.
class TradeLive(object):
def __init__(self):
self.kis = PyKis(
appkey=APPKEY,
appsecret=APPSECRET,
virtual_account=True,
)
def __enter__(self):
return self
def __exit__(self, type_unused, value_unused, traceback_unused):
pass
def run(self):
self.kis.rtclient.event.cntg.add(self.on_cntg)
self.kis.rtclient.event.oder.add(self.on_oder)
stock = self.kis.stock('000660')
stock.rt_add('์ฒด๊ฒฐ๊ฐ')
def on_cntg(self, cli: KisRTClient, res: KisRTPrice):
print(f'์๊ฐ: {res.stck_cntg_hour.strftime("%H:%M:%S")}', end=' ')
def on_oder(self, cli: KisRTClient, res: KisRTConclude):
print(f'{res.acnt_no} {res.acpt_yn_name} {res.cntg_isnm} {res.cntg_yn_name} {res.order_kind_name}', end=' ')
ํด๋์ค์ ๋ฃ์ด์ ์ฌ์ฉํ๋ฉด run_forever()๊ฐ ์๋ํ์ง ์๊ณ ์ฃฝ๋๋ฐ์. ์ด๊ฑธ ์ด๋ป๊ฒ ๊ณ ์น ์ ์์๊น์?
์๋ ํ์ธ์.
์ข์ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ๊ณต์ ํด์ฃผ์ ์ ๊ฐ์ฌ๋๋ฆฝ๋๋ค.
kis.market.kospi.all()
kis.market.kosdaq.all()
์ ์ฌ์ฉํ๊ณ ์๋๋ฐ
์ด์ง์ค229ํธ Class A ์ ๊ฐ์ด, ์ฌ์ค์ ๊ฑฐ๋๊ฐ ๋ถ๊ฐ๋ฅํ ๋ฐ์ดํฐ๋ค์ด ๋ง์ด ๋์์ ํด๋น ์ด๋ป๊ฒ ์ ๊ฑฐํด์ผํ ์ง ๊ณ ๋ฏผ ์ค์ ์์ต๋๋ค.
1๋ฒ๊ณผ 2๋ฒ์ ํ์ธํ์ฌ "kospi_issu_yn and kospi_issu_yn" ์ธ ์ข ๋ชฉ๋ง ์ ๋ณํ๋ ค๊ณ ํฉ๋๋ค.
ํํฌ์์ 10์27์ผ 17์ ์ดํ๋ก ์ ๊ทผ ํ ํฐ ๋ฐ๊ธ๋ณ๊ฒฝ์ผ๋ก 1๋ถ๋น 1ํ์ฉ๋ง ํธ์ถ๊ฐ๋ฅํ๋๋ก ๋ณ๊ฒฝ๋์ด
API๋ด์์ ๋งค๋ฒ ํ ํฐ์ ๋ฐ๊ธํ๊ธฐ ๋๋ฌธ์ 1๋ถ๋ด์ ๋ค์ ํธ์ถํ๋ฉด ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค.
ํด๊ฒฐ๋ฐฉ๋ฒ์ด ์์๊น์?
์๋ ํ์ธ์, python-kis ๊ฐ๋ฐ์๋,
๋จผ์ , ํ๋ก์ ํธ๋ฅผ ๋ง๋ค์ด ์ฃผ์
์ ๊ฐ์ฌํฉ๋๋ค. python-kis๊ฐ ํฐ ๋์์ด ๋๊ณ ์์ต๋๋ค.
ํ๋ก์ ํธ์ ๊ธฐ๋ฅ ์ค ํ๋๋ฅผ ๊ฐ์ ํ์ฌ, ํด์ธ ์ฃผ์ ์กฐํ ๋ฐ ๊ฑฐ๋ ๊ธฐ๋ฅ์ด ์ถ๊ฐ ๋์์ผ๋ฉด ํ๋ ๋ง์์์ ๊ธ์ ์ฌ๋ฆฝ๋๋ค.
๊ฐ์ฌํฉ๋๋ค.
ํด์ธ์ฃผ์ ์ทจ์ํจ์ ์คํ์์ ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค.
์์ค overseas_order_revise.py ์ 82ํ์
๋๋ค.
๊ตญ๋ด์ฃผ์ ์ต์ํ ๋ ํ์ํ ํ๋ผ๋ฉํฐ๊ฐ ๋ค์ด๊ฐ์ ์๋ฌ๊ฐ ๋ฐ์ํ๋ค์.
----์๋ฌ ๋ถ๋ถ-----
'KRX_FWDG_ORD_ORGNO': order.krx_fwdg_ord_orgno,
ํ์ธ ๋ถํ๋๋ฆฝ๋๋ค.
์๋
ํ์ธ์.
์ข์ ๋ผ์ด๋ธ๋ผ๋ฌ๋ฆฌ๋ฅผ ๊ฐ๋ฐํด ์ฃผ์
์ ๊ฐ์ฌํฉ๋๋ค.
ํ์ฌ ๊ตญ๋ด ์ฃผ์๋ง ์ฌ์ฉ๊ฐ๋ฅํ๊ฑฐ ๊ฐ์๋ฐ ํด์ธ์ฃผ์์ ์ธ์ ์ฏค ์ง์๊ฐ๋ฅํ์ค๊น์?
๋ต๋ณ ๋ถํ๋๋ฆฝ๋๋ค.
์๋ ํ์ธ์. ์ข์ ๋ผ์ด๋ธ๋ฌ๋ฆฌ ๊ฐ์ฌ๋๋ฆฝ๋๋ค.
ํํ ๋ฆฌ์ผ๋๋ก ์งํํ๋ ์ค, KOSPI ์ผ๋ด์กฐํ๋ฅผ ํด๋ณด๋ ค๊ณ ํ๋, scope/sector/api/period_sector_price๋ฅผ ์ ๋ถ ์ฃผ์์ฒ๋ฆฌ ํ ๊ฒ์ ํ์ธํ์์ต๋๋ค.
ํด๋น ์ฃผ์์ ์ง์์ ๋ค์ importํด๋, ํด๋น ํจ์๋ค์ ์ฌ์ ํ ์ฌ์ฉํ ์ ์๋๋ผ๊ณ ์.
ํน์ ์ ์ข ๊ธฐ๊ฐ๋ณ์์ธ๋ฅผ ๋ค๋ฅธ ํจ์๋ค์ ํ์ฉํด์, ํ์ธํ ์ ์๋๊ฑฐ์ง, ์๋๋ฉด ํด๋น ํจ์๋ฅผ ์ฃผ์์ฒ๋ฆฌ๋ฅผ ํด์ ํ์ฌ ๋ค์ ํ์ฉํ ์ ์๋ ๋ฐฉ๋ฒ์ด ์์๊น์?
์ค์๊ฐ ๊ด๋ จ ํจ์๊ฐ ๋์์ ์ํฉ๋๋ค.
์๋์ ๊ฐ์ ์๋ฌ๊ฐ ๋ฐ์
Traceback (most recent call last):
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\test\logs\live.py", line 37, in <module>
app.run()
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\test\logs\live.py", line 23, in run
stock.rt_add("์ฒด๊ฒฐ๊ฐ", timeout=100)
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\venv\Lib\site-packages\pykis\scope\stock\stock.py", line 72, in rt_add
return self.rtclient.add(id, self.code, timeout=timeout)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\venv\Lib\site-packages\pykis\rtclient\rtclient.py", line 352, in add
return self.register(_rtcd(id, self.key.virtual_account), tr_key, timeout=timeout)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\venv\Lib\site-packages\pykis\rtclient\rtclient.py", line 327, in register
return self._send_request(tr_id, tr_key, True, timeout=timeout)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\venv\Lib\site-packages\pykis\rtclient\rtclient.py", line 324, in _send_request
return self._wait_response(id, timeout) # type: ignore
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "C:\Users\junpa\Workspace\PycharmProjects\wSplit\venv\Lib\site-packages\pykis\rtclient\rtclient.py", line 291, in _wait_response
(future,) = as_completed([future], timeout=timeout)
^^^^^^^^^
File "C:\Program Files\WindowsApps\PythonSoftwareFoundation.Python.3.11_3.11.1776.0_x64__qbz5n2kfra8p0\Lib\concurrent\futures\_base.py", line 239, in as_completed
raise TimeoutError(
TimeoutError: 1 (of 1) futures unfinished
from pykis import *
from utils.settings import Settings
class TradeLive(object):
def __init__(self):
self.kis = PyKis(
appkey=Settings().MOCK_KIS['appkey'],
appsecret=Settings().MOCK_KIS['appsecret'],
virtual_account=True,
)
def __enter__(self):
return self
def __exit__(self, type_unused, value_unused, traceback_unused):
pass
def run(self):
self.kis.rtclient.event.cntg.add(self.on_cntg)
self.kis.rtclient.event.oder.add(self.on_oder)
stock = self.kis.stock("000660")
stock.rt_add("์ฒด๊ฒฐ๊ฐ", timeout=100)
def on_cntg(self, cli: KisRTClient, res: KisRTPrice):
print(f'์๊ฐ: {res.stck_cntg_hour.strftime("%H:%M:%S")}', end=" ")
def on_oder(self, cli: KisRTClient, res: KisRTConclude):
print(
f"{res.acnt_no} {res.acpt_yn_name} {res.cntg_isnm} {res.cntg_yn_name} {res.order_kind_name}",
end=" ",
)
app = TradeLive()
app.run()
input()
ํ์ด์ฌ 3.11
์ฐ๋ถํฌ 22.04
์๋ ํ์ธ์. ์กฐ๊ฑด๊ฒ์ API๊ฐ ์ถ๊ฐ ๋์๋๋ฐ ๊ธฐ๋ฅ ์ถ๊ฐ ๊ฐ๋ฅํ ๊น์?
dvsn = BUY_CELL_DVSN[dvsn] # type: ignore
BUY_CELL_DVSN_TYPE ๋ "0", "1", "2" ๋ก ์ ์๋๋๋ฐ
์ฌ๋ฐ๋ฅธ ์
๋ ฅ์ "00", "01", "02" ์ด๋ผ์ ์ค์ ์๋ต์ ๋ชป๋ฐ๋๊ฑธ๋ก ํ๋จ๋จ
(๋ค๋ง ๋ชจ์๊ณ์ข์์๋ ์ด๋ค ์ฌ์ ์์์ธ์ง ์ ๋๋ก ์ถ๋ ฅ ๋จ)
์ค์ ๊ณ์ข์์๋
class KisStockDailyOrder(KisDynamic):
infm_tmd: time
์ ์๋ต์ ๋ฐ์ง ์์
๋ฐ๋ผ์,
class KisDynamic:
elif type == time:
return datetime.strptime(value, '%H%M%S').time()
์ฝ๋์์ datetime.strptime ํจ์๋ฅผ ์ฌ์ฉํ ๋, ๋น ๋ฌธ์์ด์ด ๋ค์ด์ค๋ ๊ฒฝ์ฐ๋ฅผ ์ฒ๋ฆฌํ๋ ์์ธ ์ฒ๋ฆฌ ๋ก์ง์ ์ถ๊ฐํ ํ์๊ฐ ์์
์ผ๋ถ ๊ณ์ข์์ balance_all() ํจ์์ ๋ฌดํ๋ฃจํ ํ์์ด ์กด์ฌํฉ๋๋ค.
์ฃผ์์๊ณ ์กฐํ API ํธ์ถ ํ 50 ๊ฐ ์ด์์ ์ข
๋ชฉ์ด ์๋ ๊ฒฝ์ฐ์
์ฐ์ ์กฐํ๊ฐ ์ด๋ฃจ์ด์ง๋๋ฐ, ์ฐ์ ์กฐํ ๊ณผ์ ์์ Loop์ ๋น ์ง๋ ๊ฒ ๊ฐ์ต๋๋ค.
ํด๋น ํ ์คํธ ๊ณ์ข๋ ์ ํํ 50์ข ๋ชฉ๋ง ๋ณด์ ํ ๊ณ์ข์ ๋๋ค.
while loop์ ๋น ์ ธ์ ๋์ค์ง ๋ชปํจ
ํ์ด์ฌ ๋ฒ์ : 3.10
ํน์ ์ฝ์คํผ / ์ฝ์ค๋ฅ์ ์กฐํํ ์ ์๋ ํจ์๊ฐ ์กด์ฌํ ๊น์?
์ผ๋จ ์ฐพ์ง ๋ชปํ์ฌ ์ง์ API๋ฅผ ๊ฐ๋ฐํด์ ์ฌ์ฉํ๊ณ ์๋๋ฐ, API ์๋ต์ด ์ด์ํ ๊ฒฝ์ฐ๊ฐ ๋ง๋๋ผ๊ณ ์
์กด์ฌํ๋์ง ์ง์๋๋ฆฌ๊ณ ์ถ์ต๋๋ค :)
name: ๋ฒ๊ทธ ์ ๋ณด
about: ์๋ ๋์ง ์์ ๋ฒ๊ทธ๋ฅผ ์ ๋ณดํฉ๋๋ค.
title: "์ค์๊ฐ ํด์ ์์ฒญ์ด ์ ์์ ์ผ๋ก ๋์ง ์์ต๋๋ค."
labels: ๋ฒ๊ทธ
assignees: ''
์ค์๊ฐ ํด์ ์์ฒญ์ด ์ ์์ ์ผ๋ก ๋์ง ์์ต๋๋ค.
def _send_request(
self,
tr_id: str,
tr_key: str,
tr_type: bool,
timeout: int = 10,
verbose: bool = True,
) -> KisRTSysResponse | None:
id = self._mkid(tr_id, tr_key)
if (id in self.subscribed):
return None
id in self.subscribed ์ ์ํด ๊ตฌ๋
์ค์ธ์ง ํ์ธํ๋๋ฐ, ๊ตฌ๋
์ค์ธ ์ข
๋ชฉ์ ํด์ ํ๊ณ ์ ํ๋๋ผ๋ None์ ๋ฐํํ๊ณ ์์ต๋๋ค.
์ฆ ๊ตฌ๋
ํด์ ๋ฅผ ์์ฒญํ๊ธฐ๋ ์ ์ None์ ๋ฐํํฉ๋๋ค.
if (id in self.subscribed) &(tr_type ==True):
return None
๋ฑ์ผ๋ก ์์ ํ๋ฉด ํด๊ฒฐ๋ ๊ฒ ๊ฐ์ต๋๋ค.
ํ์ด์ฌ ๋ฒ์ : 3.11
[๊ท์ฐฎ์ผ์๋ฉด ์ ์จ๋ ๋ผ์...]
์ด๋ฆ | ๋ฒ์ |
---|---|
requests | ? |
SQLAlchemy | ? |
websocket-client | ? |
pycryptodome | ? |
colorlog | ? |
์์ง ๊ณ์ ๋ด์ผ๊ฒ ์ง๋ง ์ ๊ฐ ์ฒ์๋ถํฐ ์ง๋๊ฑฐ๋ณด๋ค ๋๋ฌด๋ ์ฒด๊ณ์ ์ผ๋ก ํด๋์ผ์
์ ๊ฐํ์ด๋ค์
์ต์
์ ์๋๋๋ผ๋ ๊ตญ๋ด์ ๋ฌผ๊น์ง๋ง ๊ธฐ๋ฅ ์ถ๊ฐ ํด์ฃผ์ค ์ ์์๊น์?
[๋ฌธ์ฅ์ ์ง์ฐ๊ณ , ๊ธฐ๋ฅ์ ๋ํ ์์ฉ์ ์์ฑํฉ๋๋ค.]
[๋ฌธ์ฅ์ ์ง์ฐ๊ณ , ์ง๋ฌธ ๋ด์ฉ์ ์์ฑํฉ๋๋ค.]
์๋ ์ข
๋ชฉ ํ์ฑ ๊ธฐ๋ฅ Deactivate ๋ฐฉ๋ฒ ์ง์๋๋ฆฝ๋๋ค.
๋ง์ฝ ์ด๋ ต๋ค๋ฉด ํด๋น ํ์ฑ๋ ์ ๋ณด๋ค์ด ์ด๋์ ์ฌ์ฉ๋๋์ง ์ ์ ์์๊น์?
์ธ๋ฒ์ค pykis.scope.stock.stock.KisStockScope object at 0x00000262A1C46BC0> ์ข
๋ชฉ์ฝ๋ 114800 ๊ฐ์ฒด์
stock.period_price๋ฅผ ์ ์ฉ ์ ๋ฐ์ํ๋ " ValueError: ์ฃผ์์ด ์๋๋๋ค. " ์ค๋ฅ๊ฐ ๋ฐ์ํฉ๋๋ค.
ํน์ ์ฃผ์๊ณผ ๊ฐ์ด ๊ธฐ๊ฐ๋ด์ ๋ฐ์ ์ ์๋ ๋ฐฉ๋ฒ์ด ์์๊น์?
ETF ์ ์ ์ฉํ๋ฉด ๋ฌธ์ ๊ฐ ์๊ฒจ์ ์์ ๊ฐ์ ์์ธ์ฒ๋ฆฌ๋ฅผ ๋ฃ์ผ์ ๊ฒ์ธ์ง ๊ถ๊ธํฉ๋๋ค.
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.