티스토리 뷰

logo.png
0.01MB

tkinter를 통해 ui 프로그램 작성

입력한 웹싸이트의 패스워드를 data.txt 파일로 저장

패스워드 생성을 자동화하고, 생성한 패스워드를 생성 시점에 클립보드에 저장

from tkinter import *
from tkinter import messagebox
from random import choice, randint, shuffle
import pyperclip

# -----------------gen password----------------------#
def gen():
    password_entry.delete(0,20)  #생성 전에 화면의 패스워드 엔트리엣 삭제
    letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']
    numbers = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9']
    symbols = ['!', '#', '$', '%', '&', '(', ')', '*', '+']

    # for char in range(nr_letters):
    #   password_list.append(random.choice(letters))
    #
    # for char in range(nr_symbols):
    #   password_list += random.choice(symbols)
    #
    # for char in range(nr_numbers):
    #   password_list += random.choice(numbers)

    # 반복문을 리스트 컨프리핸션으로 구현
    password_letters = [choice(letters) for _ in range(randint(6,8))]
    password_numbers = [choice(numbers) for _ in range(randint(1,2))]
    password_symbers = [choice(symbols) for _ in range(randint(1,2))]

    password_list = password_letters + password_numbers + password_symbers
    shuffle(password_list)

    # password = ""
    # for char in password_list:
    #   password += char

    # 반복문을 join 모듈로 구현
    password = "".join(password_list)

    # 콘솔 확인용
    print(f"{password_list}\n")
    print(f"Your password is: {password}")

    # 패스워드 생성과 동시에 클립보드에 복사
    pyperclip.copy(password)

    # 패스워드 위치에 생성한 패스워드 표현
    password_entry.insert(0,password)

# -----------------save password_label----------------------#
def save():
    website = website_entry.get()
    email = email_entry.get()
    password = password_entry.get()

    if len(website) == 0 or len(email)==0 or len(password)==0:
        messagebox.showinfo(title="Warning", message="Please don't leave any fields empty!")
    else:
        is_ok=messagebox.askokcancel(title=website,message=f"These are the details entered: \nEmail: {email}\nPassword: {password} \nIs it ok to save?")
        if is_ok:
            with open("data.txt", "a") as data_file:  ## data_file=open("data.txt","a")  #이렇게 열면 close()로 닫아야 함
                data_file.write(f"{website} | {email} | {password}\n")
                website_entry.delete(0, END)
                email_entry.delete(0, END)
                password_entry.delete(0, END)

window = Tk()
window.title("Password Manager")
window.config(padx=20, pady=20)

canvas = Canvas(height=200, width=200)
logo_img = PhotoImage(file="logo.png")
canvas.create_image(100, 100, image=logo_img)
# logo_label=Label(text="MyPass")
canvas.grid(row=0, column=1)

# Labels
website_label = Label(text="Website:")
website_label.grid(row=1, column=0)

email_label = Label(text="Email/Username:")
email_label.grid(row=2, column=0)

password_label = Label(text="Password:")
password_label.grid(row=3, column=0)

# Entries
website_entry = Entry(width=35)
website_entry.grid(row=1, column=1, columnspan=2)
website_entry.focus()
email_entry = Entry(width=35)
email_entry.grid(row=2, column=1, columnspan=2)
email_entry.insert(0, "test@test.com")
password_entry = Entry(width=21)
password_entry.grid(row=3, column=1)

# Buttons
generate_password_button = Button(text="Generate Password", command=gen)
generate_password_button.grid(row=3, column=2)
add_button = Button(text="Add", width=36, command=save)
add_button.grid(row=4, column=1, columnspan=2)

window.mainloop()

'Test > Python(20220101~)' 카테고리의 다른 글

나만의 예외, raise  (0) 2022.09.18
Days30. 예외 포착하고 다루기(try,except,else,finally)  (0) 2022.09.14
1차 2급 연습1  (0) 2022.06.06
Days29. Password manager - 2  (0) 2022.05.22
Days29. Password manager - 1 (tkinter)  (0) 2022.05.21
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/08   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
글 보관함