Qt/PyQt5 강좌
PyQt5 검색창 UI 예제
webnautes
2024. 8. 12. 22:32
반응형
PyQT5로 만든 검색창 UI 예제입니다.
2024. 8. 11 최초작성
검색어를 입력 후, 버튼을 클릭하면 해당 단어들에 하이라이트가 표시됩니다.
import sys import random from PyQt5.QtWidgets import QApplication, QWidget, QLineEdit, QPushButton, QVBoxLayout, QTextEdit from PyQt5.QtGui import QTextCharFormat, QBrush, QColor from PyQt5.QtGui import QTextDocument from PyQt5.QtGui import QTextCursor class SearchApp(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): # UI 구성요소 생성 self.search_input = QLineEdit() self.search_button = QPushButton('검색') self.search_button.clicked.connect(self.perform_search) self.result_output = QTextEdit() self.result_output.setReadOnly(True) # 레이아웃 설정 layout = QVBoxLayout() layout.addWidget(self.search_input) layout.addWidget(self.search_button) layout.addWidget(self.result_output) # 윈도우 설정 self.setLayout(layout) self.setGeometry(300, 300, 800, 800) self.setWindowTitle('검색 애플리케이션') self.show() # 초기 텍스트 설정 text = ''' 동물 친구들 토끼 토끼 깡충깡충 긴 귀를 쫑긋쫑긋 곰돌이 곰돌이 느림보 꿀을 찾아 쿨쿨쿨 원숭이 원숭이 재주꾼 나무 타고 놀자놀자 기린 기린 목이 길어 하늘 구름 만져볼까 코끼리 코끼리 큰 귀를 팔랑팔랑 흔들어요 펭귄 펭귄 뒤뚱뒤뚱 얼음 위를 걸어가요 사자 사자 으르렁 숲의 왕은 나야나 토끼 곰돌이 원숭이 기린 코끼리 펭귄 사자 우리 모두 친구 친구 ''' self.result_output.append(text) def perform_search(self): # 검색 수행 search_text = self.search_input.text() self.highlight_text(search_text) def highlight_text(self, text): list_word = text.split(' ') # 이전 하이라이트 제거 cursor = self.result_output.textCursor() cursor.select(QTextCursor.Document) format = QTextCharFormat() format.setBackground(QBrush(QColor("white"))) # 또는 self.result_output의 기본 배경색 cursor.mergeCharFormat(format) for word in list_word: # 새로운 검색 및 하이라이트 format = QTextCharFormat() random_color = QColor(random.randint(100, 255), random.randint(100, 255), random.randint(100, 255)) format.setBackground(QBrush(random_color)) cursor.setPosition(0) self.result_output.setTextCursor(cursor) find_flags = QTextDocument.FindFlags() find_flags &= ~QTextDocument.FindCaseSensitively # 검색 및 하이라이트 로직 while self.result_output.find(word, find_flags): cursor = self.result_output.textCursor() cursor.mergeCharFormat(format) self.result_output.setTextCursor(cursor) # 마지막 선택 상태 해제 cursor = self.result_output.textCursor() cursor.clearSelection() self.result_output.setTextCursor(cursor) # 커서를 문서의 끝으로 이동 cursor.movePosition(QTextCursor.End) self.result_output.setTextCursor(cursor) if __name__ == '__main__': app = QApplication(sys.argv) ex = SearchApp() sys.exit(app.exec_()) |
반응형