기본 콘텐츠로 건너뛰기

[ML] 결정트리(Decision Tree) 모델

파일 관리

내용

파일 관리

os 모듈

파이썬의 os 모듈을 사용하여 디렉토리(directory)를 조정할 수 있습니다.

함수 내용
getcwd() 현재 인터프리터가 작동되고 있는 디렉토리(Current Working Directory)를 나타냄, 문자열 형식
getcwdb() getcwd()와 동일하지만 bytes 형식으로 반환
chdir() 현재 working directory를 다른 디렉토리로 변경
listdir() working directory의 모든 하위디렉토리와 파일의 목록을 반환
mkdir() 지정된 경로에 새로운 디렉토리를 생성. 경로를 지정하지 않으면 working directory에 생성
rename(이름, 교체할 이름) 디렉토리의 이름을 교체
remove() 파일을 삭제
rmdir() 빈 디렉토리를 제거
import os
​
os  #모듈의 경로 반환
<module 'os' from 'C:\home\~\anaconda3\lib\os.py'>
#getcwd()
current=os.getcwd();current
'/home/~/python_programming'
type(current)
str
current2=os.getcwdb(); current2
b'/home/~/\xeb\xac\xb8\xec\x84\x9c/python_programming'
type(current2)
bytes
#chdir()
os.chdir("/home/~/문서")
os.getcwd()
'/home/~/문서'
#listdir()
os.getcwd()
'/home/~/python_programming'
os.listdir()
['python_programming_eng.epub',
'__pycache__',
...
'polymorphism.py',
'test1.txt']
#mkdir()
 os.getcwd()
'/home/~/test'
os.listdir()
[]
os.mkdir('subtest')
os.listdir()
['subtest']
#rename()
os.rename("subtest", "newTest")
os.listdir()
['newTest']
#remove(), rmdir()
os.listdir()
['test.txt']
os.remove("test.txt")
os.listdir()
[]
os.chdir('/~/test')
os.listdir()
['newTest']
os.rmdir("newTest")
os.listdir()
[]

rmdir()은 빈 디렉토리에서만 작동됩니다. 디렉토리내에 하위 디렉토리나 파일이 존재할 경우 이 명령은 예외를 발생시킵니다.

try:
 os.rmdir('test1')
except:
 print("내부에 내용물이 있으므로 삭제되지 않았습니다.")
내부에 내용물이 있으므로 삭제되지 않았습니다. 

os.path 모듈

os 모듈내에 있는 하위모듈로서 파일이나 폴더에 대한 정보를 알려줍니다.

함수내용
isdir() 지정된 이름이 폴더인지를 판단하여 True/False반환
지정된 이름의 폴더가 없어도 False, 그 이름이 파일이라도 False를 반환
isfile() isdir()과 유사하지만 폴더가 아닌 파일인지를 판단
exists() 파일이나 폴더가 존재하는가를 판단
getsize() 파일의 크기를 반환(byte단위로 표시), 폴더의 크기는 반환하지 못함
split() 파일과 폴더의 경로를 구분해 주는 함수
경로 중의 마지막에 존재하는 것을 분리
splitext()마지막 파일의 확장명을 따로 분리하여 반환
마지막이 폴더일 경우 분리되지 않음
join() 파일이름과 폴더 이름을 합쳐주는 함수
dirname() 경로의 폴더만을 분취하여 나타내는 함수
basename() 경로에서 파일만을 분취하여 나타내는 함수
os.path.isdir('reg_fig')
True
os.path.isdir('test.db')
False
os.path.isfile('test.db')
True
os.path.exists('test')
False
os.path.exists('test.db')
True
os.path.getsize('function_names.xlsx')
19037
os.path.getsize('c:/python')
4096
os.path.split("C:\\Users\\~\\~\\python_web\\sys_os_module.ipnyb")
 ('C:\\Users\\~\\~\\python_web', 'sys_os_module.ipnyb')
os.path.split("C:\\Users\\~\\~\\python_web\\reg_fig")[1]
'reg_fig'
os.path.splitext("C:\\Users\\~\\~\\python_web\\sys_os_module.ipnyb")
 ('C:\\Users\\~\\~\\python_web\\sys_os_module', '.ipnyb')
os.path.splitext("C:\\Users\\~\\~s\\python_web\\reg_fig")
 ('C:\\Users\\~\\~\\python_web\\reg_fig', '')
x=os.path.split("C:\\Users\\~\\~\\python_web\\sys_os_module.ipnyb")
os.path.join(x[0], x[1])
'C:\\Users\\~\\~\\python_web\\sys_os_module.ipnyb'
#폴더만을 분취하여 나타냄
os.path.dirname("C:\\Users\\~\\~\\python_web\\sys_os_module.ipnyb")
'C:\\Users\\~\\~\\python_web'
#파일이름을 분취하여 나타냄
os.path.basename("C:\\Users\\~\\~\\python_web\\sys_os_module.ipnyb")
'sys_os_module.ipnyb'

sys 모듈

설치된 파이썬에 대한 많은 정보들은 sys 모듈을 사용하여 확인할 수 있습니다. 빈번히 사용되는 함수들은 다음과 같습니다.

함수 내용
sys.builtin_module_namesimport의 명령없이 사용할 수 있는 내장 모듈을 확인
sys.path 모듈을 찾을 특정경로를 보여줌
sys.path.append 모듈을 이용하여 모듈을 찾을 경로를 첨가할 수 있다.
예) sys.path.append('/foo/bar') 이러한 경로 첨가는 PYTHONPATH 환경변수를 설정하는 것과 거의 동일하다.
import sys
sys.modules['os']
<module 'os' from 'C:\\Users\\~\\Anaconda3\\lib\\os.py'>
sys.builtin_module_names
('_abc',
'_ast',
&vellips;
'itertools',
'marshal',
'math',
&vellips;
'sys',
'time',
'winreg',
'xxsubtype',
'zlib')
sys.path
['C:\Users\~\anaconda3\python39.zip',
&vellips;
'C:\Users\~\anaconda3\lib\site-packages\win32\lib',
'C:\Users\~\anaconda3\lib\site-packages\Pythonwin']
sys.path.append('C:\\Users\\~\\~\\note\\python\\산책')
sys.path
['C:\Users\~\~\note\python\산책',
'C:\Users\~\anaconda3\python39.zip',
&vellips;
'C:\Users\~\anaconda3\lib\site-packages\win32\lib',
'C:\Users\~\anaconda3\lib\site-packages\Pythonwin']

댓글

이 블로그의 인기 게시물

[Linear Algebra] 유사변환(Similarity transformation)

유사변환(Similarity transformation) n×n 차원의 정방 행렬 A, B 그리고 가역 행렬 P 사이에 식 1의 관계가 성립하면 행렬 A와 B는 유사행렬(similarity matrix)이 되며 행렬 A를 가역행렬 P와 B로 분해하는 것을 유사 변환(similarity transformation) 이라고 합니다. $$\tag{1} A = PBP^{-1} \Leftrightarrow P^{-1}AP = B $$ 식 2는 식 1의 양변에 B의 고유값을 고려한 것입니다. \begin{align}\tag{식 2} B - \lambda I &= P^{-1}AP – \lambda P^{-1}P\\ &= P^{-1}(AP – \lambda P)\\ &= P^{-1}(A - \lambda I)P \end{align} 식 2의 행렬식은 식 3과 같이 정리됩니다. \begin{align} &\begin{aligned}\textsf{det}(B - \lambda I ) & = \textsf{det}(P^{-1}(AP – \lambda P))\\ &= \textsf{det}(P^{-1}) \textsf{det}((A – \lambda I)) \textsf{det}(P)\\ &= \textsf{det}(P^{-1}) \textsf{det}(P) \textsf{det}((A – \lambda I))\\ &= \textsf{det}(A – \lambda I)\end{aligned}\\ &\begin{aligned}\because \; \textsf{det}(P^{-1}) \textsf{det}(P) &= \textsf{det}(P^{-1}P)\\ &= \textsf{det}(I)\end{aligned}\end{align} 유사행렬의 특성 유사행렬인 두 정방행렬 A와 B는 'A ~ B' 와 같

[matplotlib] 히스토그램(Histogram)

히스토그램(Histogram) 히스토그램은 확률분포의 그래픽적인 표현이며 막대그래프의 종류입니다. 이 그래프가 확률분포와 관계가 있으므로 통계적 요소를 나타내기 위해 많이 사용됩니다. plt.hist(X, bins=10)함수를 사용합니다. x=np.random.randn(1000) plt.hist(x, 10) plt.show() 위 그래프의 y축은 각 구간에 해당하는 갯수이다. 빈도수 대신 확률밀도를 나타내기 위해서는 위 함수의 매개변수 normed=True로 조정하여 나타낼 수 있다. 또한 매개변수 bins의 인수를 숫자로 전달할 수 있지만 리스트 객체로 지정할 수 있다. 막대그래프의 경우와 마찬가지로 각 막대의 폭은 매개변수 width에 의해 조정된다. y=np.linspace(min(x)-1, max(x)+1, 10) y array([-4.48810153, -3.54351935, -2.59893717, -1.65435499, -0.70977282, 0.23480936, 1.17939154, 2.12397372, 3.0685559 , 4.01313807]) plt.hist(x, y, normed=True) plt.show()

R 미분과 적분

내용 expression 미분 2차 미분 mosaic를 사용한 미분 적분 미분과 적분 R에서의 미분과 적분 함수는 expression()함수에 의해 생성된 표현식을 대상으로 합니다. expression expression(문자, 또는 식) 이 표현식의 평가는 eval() 함수에 의해 실행됩니다. > ex1<-expression(1+0:9) > ex1 expression(1 + 0:9) > eval(ex1) [1] 1 2 3 4 5 6 7 8 9 10 > ex2<-expression(u, 2, u+0:9) > ex2 expression(u, 2, u + 0:9) > ex2[1] expression(u) > ex2[2] expression(2) > ex2[3] expression(u + 0:9) > u<-0.9 > eval(ex2[3]) [1] 0.9 1.9 2.9 3.9 4.9 5.9 6.9 7.9 8.9 9.9 미분 D(표현식, 미분 변수) 함수로 미분을 실행합니다. 이 함수의 표현식은 expression() 함수로 생성된 객체이며 미분 변수는 다음 식의 분모의 변수를 의미합니다. $$\frac{d}{d \text{변수}}\text{표현식}$$ 이 함수는 어떤 함수의 미분의 결과를 표현식으로 반환합니다. > D(expression(2*x^3), "x") 2 * (3 * x^2) > eq<-expression(log(x)) > eq expression(log(x)) > D(eq, "x") 1/x > eq2<-expression(a/(1+b*exp(-d*x))); eq2 expression(a/(1 + b * exp(-d * x))) > D(eq2, "x") a * (b * (exp(-d * x) * d))/(1 + b