-
은행 예금으로만 노후준비를 하면 안되는 이유자산배분 투자 2020. 3. 24. 17:58
노후 준비를 위한 자산을 확보하기 위한 방법은 여러가지가 있다. 여기서는 그 중 은행예금에 대해 분석해 보자.
최근 읽은 책에서 정기예금에 대한 내용을 보았다.
예금만 하면 되지 위험까지 감수하며 투자해서 수익률을 높여야 하나?' 하는 질문이 나오는 것은 당연하다. 위험을 피하고 싶은 것은 당연한 심리다. 그럼에도 '위험'을 감수하고 투자해야 한다는데 '위험'은 무엇인가? 투자에서 위험은 '손실가능성'과 '불확실성'이다. 첫번째 위험은 돈을 잃을 가능성을 말한다. 손실이 난다는 말이다. 수익을 얻고자 하는 게임에서의 위험이란 직관적으로도 돈을 잃는 것이라는 게 이해가 간다. 문제는 투자를 하지 않았는데도 돈을 잃고 있다는 것이다. 많은 사람이 눈치 채지 못하고 있는, 가만히 있는데도 돈을 잃는 이유는 "인플레이션" 때문이다. 1996년부터 2018년까지 우리나라의 정기예금 이자율 자료를 조사했다. 조사 기간 동안의 이자소득세가 변화한 부분을 반영해 세후 실질수익률을 계산했다. 예금으로 이자를 받아도 실제로는 손해가 났다. 금융위기 시절만이 아닌 2014년~2017년까지도 그랬다. 이런 시기를 '실질금리 마이너스 시대'라고 한다. 실질금리 마이너스란 금리가 물가상승률을 따라가지 못한다는 말이다. 금리만으로는 애써 모은 돈의 가치를 지킬 수가 없다. - 마법의 연금 굴리기(김성일) 페이지 77-79
최근 파이썬(python) pandas를 이용한 데이터 분석에 중독되어 있다. 이런 내용을 보면 내가 직접 분석하고 싶은 충동이 강하게 생긴다. 아래는 1996년부터 현재까지 정기예금 금리에 대한 분석이다.
소스코드와 분석 결과는 맨 아래에 첨부해 두었다.
목적¶
- 최근 몇 년간 지속된 저금리기조로 정기예금 금리가 낮은 편이다.
- 정기예금금리에 대하여, 이자소득세와 물가상승율을 고려한 실질금리의 추세를 살펴보자.
- 고려사항
- 기간: 1996년 ~ 2020년 1월(최근)
- 상품: 1년만기 정기예금
- 기간 중 이자소득세 변동 내역을 반영한다.
- 데이터
- 정기예금금리 데이터 한국은행 경제통계시스템 4.2.1.1 신규취급액 기준
- 소비자물가지수 데이터 한국은행 경제통계시스템 7.4.1 소비자물가지수(2015=100)
- 국내 이자소득세율 변화 이력 pinterest 검색
In [1]:import pandas as pd from pandas import Series, DataFrame import numpy as np import matplotlib.pyplot as plt from datetime import datetime, timedelta from IPython.display import Image from IPython.core.display import display, HTML #Jupyter Notebook을 Tistory에 업로드하기 위한 설정 display(HTML("<style>.container {width:90% !important;}</style>"))
In [2]:물가 = pd.read_csv('소비자물가지수.csv', engine='python', header=None, skiprows=5, index_col=0, parse_dates=True) 물가.index.name = '일시' 물가.rename(columns={1: '소비자물가지수'}, inplace=True) 물가['물가상승율'] = np.round(물가['소비자물가지수'].pct_change(12) * 100, 2)
In [3]:물가[:15]
Out[3]:In [4]:예금 = pd.read_csv('정기예금금리.csv', engine='python', header=None, skiprows=4, index_col=0, parse_dates=True) 예금 = 예금[6] 예금 = DataFrame(예금) 예금.index.name = '일시' 예금.rename(columns={6: '예금금리(세전)'}, inplace=True) 예금.dropna(how='all', inplace=True)
In [5]:예금.head()
Out[5]:이자소득세율 이력¶
In [6]:Image(filename='이자소득세율_변화.jpg')
Out[6]:이자소득세율을 구하기 위한 함수¶
In [7]:def get_ts(start, end, interest): return Series(interest, index=pd.date_range(start - timedelta(1), end, freq='M') + timedelta(1))
In [8]:기간_이자소득세 = { (datetime(1991,1,1), datetime(1995,12,1)): 0.215, (datetime(1996,1,1), datetime(1997,12,1)): 0.165, (datetime(1998,1,1), datetime(1998,9,1)): 0.22, (datetime(1998,10,1), datetime(1999,12,1)): 0.242, (datetime(2000,1,1), datetime(2000,12,1)): 0.22, (datetime(2001,1,1), datetime(2004,12,1)): 0.165, (datetime(2005,1,1), datetime(2020,3,1)): 0.154, }
In [9]:result = [] for date, interest in 기간_이자소득세.items(): result.append(get_ts(date[0], date[1], interest)) 이자소득세 = DataFrame(pd.concat(result, axis=0)) 이자소득세.rename(columns={0: '이자소득세'}, inplace=True)
In [10]:이자소득세.head()
Out[10]:물가, 예금, 이자소득세를 하나의 DataFrame으로 통합¶
In [11]:df= pd.merge(pd.merge(물가, 예금, left_index=True, right_index=True), 이자소득세, left_index=True, right_index=True)
In [12]:df.head()
Out[12]:이자소득세를 고려한 세후예금금리¶
In [13]:df['예금금리(세후)'] = np.round(df['예금금리(세전)'] * (1 - df['이자소득세']), 2)
In [14]:df.head()
Out[14]:물가상승율을 고려한 실질예금금리¶
In [15]:df['실질금리'] = df['예금금리(세후)'] - df['물가상승율']
In [16]:df.head()
Out[16]:주요 이벤트들¶
In [17]:crisis_data = [ (datetime(1997, 12, 3), 'IMF 구제금융'), (datetime(2008, 9, 15), '리먼브라더스 파산'), (datetime(2020, 1, 22), '코로나바이러스 확산') ]
In [18]:fig, ax = plt.subplots(figsize=(12, 8)) ax.plot((datetime(1995,1,1), datetime(2021, 1,1)), (0, 0), color='black', linestyle='--', linewidth=5, alpha=0.7) df[['물가상승율', '예금금리(세후)', '실질금리']].plot(kind='line', ax=ax) ax.tick_params(axis='both', which='major', labelsize=12) ax.set_xlabel('연도', fontsize=15) title = '1996~2020 1년만기 정기예금금리(세후) 및 물가상승율' plt.title(title, fontsize=20) for date, label in crisis_data: ax.annotate(label, xy=(date, df['예금금리(세후)'].asof(date)), xytext=(date, df['예금금리(세후)'].asof(date) + 3.5), arrowprops=dict(facecolor='black', headwidth=4, width=2, headlength=4), horizontalalignment='left', verticalalignment='top', fontsize=15) plt.show()
In [19]:df[df['실질금리'] < 0]
Out[19]:결과를 파일로 추출¶
In [20]:title = '1996~2020 1년만기 정기예금금리(세후) 및 물가상승율' df.to_excel(title + '.xlsx') plt.savefig(title + '.png')
In [ ]:반응형'자산배분 투자' 카테고리의 다른 글
Maxims for sustainable investment in stock market (0) 2020.04.01 ETF 자산배분투자 매매량 계산 파이썬 코드 (0) 2020.03.30 [파이썬 크롤링, ETF 자산배분투자] 실시간 주가 확인 네이버 vs 다음 [2] (0) 2020.03.28 [파이썬 크롤링, ETF 자산배분투자] 실시간 주가 확인 네이버 vs 다음 [1] (0) 2020.03.27 당신의 노후는 안녕한가? (0) 2020.03.08