- 검색 폴더 선택 기능
- 파일 크기를 입력하여 해당 크기보다 큰 파일 검색 기능
- 검색된 파일 목록을 GUI 텍스트 창에 표시
- 검색 결과를 파일로 저장하는 기능
- 이 코드를 실행하면 GUI 창이 나타나며, 원하는 폴더를 선택하고 파일 크기를 입력한 후 “Search” 버튼을 클릭하여 파일을 검색할 수 있습니다. 검색 결과는 GUI 텍스트 창에 표시되며, “Save” 버튼을 클릭하여 결과를 파일로 저장할 수 있습니다.
1. 모듈 임포트
import sys import os import time from PyQt5.QtWidgets import * from PyQt5 import uic, QtCore, QtGui, QtWidgets
sys: 시스템과 관련된 파이썬 모듈로, 명령행 인수 및 스크립트 종료와 같은 시스템 기능을 제공합니다.os: 운영체제와 상호 작용하는 파이썬 모듈로, 파일 및 디렉터리 관리 등의 작업을 수행합니다.time: 시간과 관련된 파이썬 모듈로, 시간 지연 및 측정 기능을 제공합니다.PyQt5: Qt 프레임워크를 사용한 GUI 애플리케이션을 개발하기 위한 모듈입니다.uic: Qt Designer를 통해 디자인한 UI 파일을 로드하는 모듈입니다.
2. UI 파일로드
form_class = uic.loadUiType("winsearch5.ui")[0]
uic.loadUiType("winsearch5.ui")를 통해 Qt Designer에서 디자인한 UI 파일 “winsearch5.ui”를 로드하고, 해당 UI에 대한 클래스를 가져옵니다.
3. 클래스 정의
class MyWindow(QMainWindow, form_class):
QMainWindow 및 form_class 클래스를 상속하는 MyWindow 클래스를 정의합니다.
4. 클래스 초기화 및 UI 설정
def __init__(self):
super().__init__()
self.setupUi(self)
# UI 설정 및 이벤트 핸들러 연결
MyWindow 클래스의 초기화 메서드로, UI를 초기화하고 이벤트 핸들러를 설정합니다.
5. 파일 검색 메서드
def searchFile(self):
# 파일 검색 및 결과 표시
사용자가 입력한 폴더에서 파일을 검색하고, 결과를 GUI 텍스트 창에 표시합니다.
6. 폴더 선택 메서드
def selectFolder(self):
# 검색할 폴더 선택
사용자에게 폴더를 선택하도록 대화상자를 열어주는 메서드입니다.
7. 폴더 선택 메서드
def saveFile(self):
# 검색 결과를 파일로 저장
검색된 결과를 파일로 저장하는 메서드입니다.
8. 이벤트 처리 메서드
def clickMethod(self):
# 경고 메시지 표시
9. 어플리케이션 실행
app = QApplication(sys.argv) window = MyWindow() window.show() app.exec_()
- PyQt5 애플리케이션을 초기화하고
MyWindow클래스의 인스턴스를 생성하며, 애플리케이션 이벤트 루프를 실행합니다.
이 프로그램은 사용자로부터 폴더 및 파일 크기를 입력받아 해당 폴더에서 지정한 크기보다 큰 파일을 검색하고, 검색 결과를 GUI를 통해 표시하거나 파일로 저장하는 기능을 제공합니다. PyQt5를 사용하여 GUI를 만들고, Python의 os 모듈을 이용하여 파일 검색 및 크기 측정을 수행합니다.
10. 완성코드
# -*- coding: utf-8 -*-
import sys
import os
import time
from PyQt5.QtWidgets import *
from PyQt5 import uic, QtCore, QtGui, QtWidgets
form_class = uic.loadUiType("winsearch5.ui")[0]
class MyWindow(QMainWindow, form_class):
def __init__(self):
super().__init__()
self.setupUi(self)
self.pushButton.clicked.connect(self.searchFile)
self.toolButton.clicked.connect(self.selectFolder)
self.toolButton_2.clicked.connect(self.selectSaveFile)
self.pushButton_2.clicked.connect(self.saveFile)
def searchFile(self):
global folder_size_total
folder_size_total = 0
if self.lineEdit_2.text():
folder = self.lineEdit_2.text()
else:
folder = 'F:/Download'
if self.lineEdit.text():
file_size_input = self.lineEdit.text()
if int(file_size_input) < 1000:
print("파일 검색 사이즈가 너무 작습니다.(1000 bytes 이상)")
self.textEdit.setText("파일 검색 사이즈가 너무 작습니다.(1000 bytes 이상)")
self.clickMethod()
else:
self.textEdit.clear()
try:
for (path, dirs, files) in os.walk(folder):
for file in files:
try:
filename = os.path.join(path, file)
file_size = os.path.getsize(filename)
if file_size > int(file_size_input):
print("파일명 : ", filename, "\t", "파일크기 : ", file_size, "\n")
self.textEdit.append(str(filename) + "\t" + str(file_size) + " bytes")
folder_size_total += os.path.getsize(filename)
except FileNotFoundError:
pass
time.sleep(0.1)
time.sleep(0.1)
self.textEdit.append("\n폴더전체크기 : " + str(folder_size_total) + " bytes")
print(folder, "폴더전체크기 : ", folder_size_total, " Bytes")
except KeyboardInterrupt:
sys.exit()
else:
self.textEdit.setText("파일 크기를 입력해 주세요.(1000 bytes 이상)")
def selectFolder(self):
directory = str(QtWidgets.QFileDialog.getExistingDirectory())
self.lineEdit_2.setText('{}'.format(directory))
def selectSaveFile(self):
savefilename = QFileDialog.getSaveFileName(self, "Save File")
print(type(savefilename))
self.lineEdit_3.setText('{}'.format(savefilename[0]))
def saveFile(self):
savefilename = self.lineEdit_3.text()
readfile = self.textEdit.toPlainText()
if savefilename and readfile:
print(type(savefilename))
try:
with open(savefilename, 'w+', encoding='utf8') as out:
out.write(readfile + "\n")
out.close()
self.clickMethod2()
self.lineEdit_3.setText("")
except:
print("파일이 저장되지 않고, 에러가 발생하였습니다.")
else:
QMessageBox.about(self, "경고!!", "검색 결과가 없거나, 저정할 파일을 지정하지 않았습니다.")
def clickMethod(self):
QMessageBox.about(self, "주의!!", "파일 검색 사이즈가 너무 작습니다. (1000 bytes 이상)")
def clickMethod2(self):
QMessageBox.about(self, "파일저장!!", "파일이 저장되었습니다.")
app=QApplication(sys.argv)
window = MyWindow()
window.show()
print("Before event loop")
app.exec_()
print("After event loop")- form_class = uic.loadUiType(“winsearch5.ui”)[0] : 유저가 만든 UI를 로드하여 form_class변수에 할당
- app=QApplication(sys.argv) : app객체 생성
- lass MyWindow(QMainWindow, form_class): QMainWindow 모듈은 PyQt5.QtWidgets 패키지에서 가져옴
- window = MyWindow() : 생성자의 self는 window를 전달받음, 여기서 self는 MyWindow 클래스 그 자신을 의미
- widow.show() : 창을 한번만 띄움
- app.exec_() : app객체를 실행, exec_()함수의 내장 루프로 계속 창이 뜨게 만듦
- self.setupUi(self) : form_class를 UI로 사용하겠다라는 의미
- self.pushButton.clicked.connect(self.searchFile) : pushButton클릭시 searchFile함수 호출(먼저 Qt Desiner로 PushButton을 UI작업 후 코딩해야 에러가 없음)
- file_size_input = self.lineEdit.text() : Qt Desiner의 lineEdit에서 입력받은 값을 file_size_input 변수에 저장
- self.textEdit.setText(“파일 검색 사이즈가 너무 작습니다.(1000 bytes 이상)”) : Qt Desiner의 textEdit에 경고문구 안내
- QMessageBox.about(self, “주의!!”, “파일 검색 사이즈가 너무 작습니다. (1000 bytes 이상)”) : 경고창 형태로 메시지 박스를 띄움
- for (path, dirs, files) in os.walk(folder): 검색할 폴더에서 경로명, 하위디렉토리명, 파일명을 리스트로 각 각 path, dirs, files에 저장
- filename = os.path.join(path, file) : 경로 + 파일명으로 filename변수에 저장
- file_size = os.path.getsize(filename) : 위(13번) 파일의 크기를 file_size변수에 저장
- self.textEdit.append(str(filename) + “\t” + str(file_size) + ” bytes”) : Qt Desiner의 textEdit에 append로 filename과 file_size를 추가해줌
- folder_size_total += os.path.getsize(filename) : 검색폴더의 전체 크기를 구하기 위하여 if문 밖에 getsize()함수를 이용하여 파일들의 크기를 누적으로 더해줌
- time.sleep(0.1) : 프로그램이 먹통되지 않도록 일정 시간 쉬게 해줌





