python小项目编程-初级(5、词频统计,6、简单得闹钟)

news2025/2/21 17:02:26

1、词频统计

统计文本文件中每个单词出现的频率。

实现

import tkinter as tk
from tkinter import filedialog, messagebox
from collections import Counter
import re

class WordFrequencyCounter:
    def __init__(self, master):
        self.master = master
        self.master.title("词频统计")
        
        self.label = tk.Label(master, text="选择一个文本文件进行词频统计")
        self.label.pack(pady=10)

        self.select_button = tk.Button(master, text="选择文件", command=self.select_file)
        self.select_button.pack(pady=5)

        self.result_text = tk.Text(master, width=50, height=20)
        self.result_text.pack(pady=10)

    def select_file(self):
        """选择文件并统计单词频率"""
        file_path = filedialog.askopenfilename(filetypes=[("Text files", "*.txt")])
        if file_path:
            try:
                self.count_words(file_path)
            except Exception as e:
                messagebox.showerror("错误", f"读取文件时出错: {e}")

    def count_words(self, file_path):
        """统计单词频率并显示结果"""
        with open(file_path, 'r', encoding='utf-8') as file:
            text = file.read()
        
        # 统计单词频率
        words = re.findall(r'\b\w+\b', text.lower())  # 使用正则表达式提取单词并转换为小写
        word_count = Counter(words)  # 统计单词频率
        self.display_results(word_count)
        return word_count #为了UT 写了return

    def display_results(self, word_count):
        """显示单词频率结果"""
        self.result_text.delete(1.0, tk.END)  # 清空文本框
        for word, count in word_count.items():
            self.result_text.insert(tk.END, f"{word}: {count}\n")  # 打印每个单词及其频率

if __name__ == "__main__":
    root = tk.Tk()
    app = WordFrequencyCounter(root)
    root.mainloop()

测试

unittest

import unittest
from collections import Counter
from word_frequency_counter import WordFrequencyCounter  # 假设你的类在这个文件中
import tkinter as tk

class TestWordFrequencyCounter(unittest.TestCase):
    
    def setUp(self):
        """创建一个 Tkinter 窗口以便测试"""
        self.root = tk.Tk()
        self.app = WordFrequencyCounter(self.root)
        self.test_file_path = 'test_sample.txt'
        with open(self.test_file_path, 'w', encoding='utf-8') as f:
            f.write("Hello world! Hello Python. Hello, hello world.")

    def tearDown(self):
        """销毁 Tkinter 窗口"""
        self.root.destroy()

    def test_count_words(self):
        """测试单词计数功能"""
        expected_count = Counter({'hello': 4, 'world': 2, 'python': 1})

        # 使用私有方法进行测试
        word_count = self.app.count_words(self.test_file_path)
        self.assertEqual(word_count, expected_count)

    def test_display_results(self):
        """测试结果显示功能"""
        test_count = Counter({'hello': 4, 'world': 1})
        self.app.display_results(test_count)

        # 检查文本框内容
        expected_output = "hello: 4\nworld: 1\n"
        self.assertEqual(self.app.result_text.get(1.0, tk.END).strip(), expected_output.strip())

if __name__ == "__main__":
    unittest.main()

pytest


import pytest
from collections import Counter
from word_frequency_counter import WordFrequencyCounter  # 假设你的类在这个文件中
import tkinter as tk

@pytest.fixture
def app():
    """创建一个 Tkinter 窗口以便测试"""
    root = tk.Tk()
    app = WordFrequencyCounter(root)
    app.test_file_path = 'test_sample.txt'
    with open(app.test_file_path, 'w', encoding='utf-8') as f:
        f.write("Hello world! Hello Python. Hello, hello world.")
    yield app
    
    root.destroy()

def test_count_words(app):
    """测试单词计数功能"""
    expected_count = Counter({'hello': 4, 'world': 2, 'python': 1})

    # 使用私有方法进行测试
    word_count = app.count_words(app.test_file_path)
    assert word_count == expected_count

def test_display_results(app):
    """测试结果显示功能"""
    test_count = Counter({'hello': 4, 'world': 1})
    app.display_results(test_count)

    # 检查文本框内容
    expected_output = "hello: 4\nworld: 1\n"
    assert app.result_text.get(1.0, tk.END).strip() == expected_output.strip()

2、简单的闹钟

设置一个简单的闹钟,指定时间后播放提示音。

实现

import tkinter as tk
from tkinter import messagebox
from datetime import datetime
import winsound  # Windows平台播放声音
import threading
import time

class AlarmClock:
    def __init__(self, root):
        self.root = root
        self.root.title("闹铃")
        self.alarms = []

        # GUI Components
        self.label = tk.Label(root, text="设置时间 (HH:MM):")
        self.label.pack(pady=10)

        self.entry = tk.Entry(root)
        self.entry.pack(pady=10)

        self.event_label = tk.Label(root, text="事件描述:")
        self.event_label.pack(pady=10)

        self.event_entry = tk.Entry(root)
        self.event_entry.pack(pady=10)

        self.add_button = tk.Button(root, text="添加闹铃", command=self.add_alarm)
        self.add_button.pack(pady=10)

        self.alarm_listbox = tk.Listbox(root)
        self.alarm_listbox.pack(pady=10)

        self.remove_button = tk.Button(root, text="删除闹铃", command=self.remove_alarm)
        self.remove_button.pack(pady=10)

        # Start alarm checking in a separate thread
        self.check_alarms_thread = threading.Thread(target=self.check_alarms, daemon=True)
        self.check_alarms_thread.start()

    def add_alarm(self):
        time_str = self.entry.get()
        event = self.event_entry.get()

        try:
            # Validate time format
            datetime.strptime(time_str, "%H:%M")
            self.alarms.append((time_str, event))
            self.alarm_listbox.insert(tk.END, f"{time_str} - {event}")
            self.entry.delete(0, tk.END)
            self.event_entry.delete(0, tk.END)
        except ValueError:
            messagebox.showerror("无效得时间", "Please enter time in HH:MM format.")

    def remove_alarm(self):
        selected = self.alarm_listbox.curselection()
        if selected:
            self.alarm_listbox.delete(selected)
            self.alarms.pop(selected[0])

    def check_alarms(self):
        while True:
            current_time = datetime.now().strftime("%H:%M")
            for alarm in self.alarms:
                if alarm[0] == current_time:
                    winsound.Beep(1000, 2000)  # 1000Hz, 1秒
                    messagebox.showinfo("Alarm", f"Time for: {alarm[1]}")
                    self.alarms.remove(alarm)
                    self.alarm_listbox.delete(0)
            time.sleep(30)  # Check every 30 seconds

if __name__ == "__main__":
    root = tk.Tk()
    app = AlarmClock(root)
    root.mainloop()

测试:

unittest

import unittest
from datetime import datetime
from unittest.mock import patch
from AlarmClock import AlarmClock
import tkinter as tk

class TestAlarmClock(unittest.TestCase):
    def setUp(self):
        self.root = tk.Tk()
        self.app = AlarmClock(self.root)

    def test_add_alarm_valid(self):
        self.app.entry.insert(0, "12:30")
        self.app.event_entry.insert(0, "Meeting")
        self.app.add_alarm()
        self.assertEqual(len(self.app.alarms), 1)
        self.assertEqual(self.app.alarms[0], ("12:30", "Meeting"))

    def test_add_alarm_invalid(self):
        self.app.entry.insert(0, "25:00")
        self.app.event_entry.insert(0, "Invalid Time")
        self.app.add_alarm()
        self.assertEqual(len(self.app.alarms), 0)

    def test_remove_alarm(self):
        self.app.entry.insert(0, "12:30")
        self.app.event_entry.insert(0, "Meeting")
        self.app.add_alarm()
        self.app.alarm_listbox.select_set(0)
        self.app.remove_alarm()
        self.assertEqual(len(self.app.alarms), 0)

    def tearDown(self):
        self.root.destroy()

if __name__ == "__main__":
    unittest.main()

pytest

import pytest
from datetime import datetime
from unittest.mock import patch
from AlarmClock import AlarmClock
import tkinter as tk

@pytest.fixture
def app():
    root = tk.Tk()
    app = AlarmClock(root)
    yield app
    root.destroy()

def test_add_alarm_valid(app):
    app.entry.insert(0, "12:30")
    app.event_entry.insert(0, "Meeting")
    app.add_alarm()
    assert len(app.alarms) == 1
    assert app.alarms[0] == ("12:30", "Meeting")

def test_add_alarm_invalid(app):
    app.entry.insert(0, "25:00")
    app.event_entry.insert(0, "Invalid Time")
    app.add_alarm()
    assert len(app.alarms) == 0

def test_remove_alarm(app):
    app.entry.insert(0, "12:30")
    app.event_entry.insert(0, "Meeting")
    app.add_alarm()
    app.alarm_listbox.select_set(0)
    app.remove_alarm()
    assert len(app.alarms) == 0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2302027.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信小程序(uni)+蓝牙连接+Xprint打印机实现打印功能

1.蓝牙列表实现&#xff0c;蓝牙设备展示&#xff0c;蓝牙连接 <template><view class"container"><view class"container_top"><view class"l">设备名称</view><view class"r">{{state.phoneNam…

Eclipse自动排版快捷键“按了没有用”的解决办法

快捷键按了没有用&#xff0c;通常是因为该快捷键方式被其他软件占用了&#xff0c;即别的软件也设置了这个快捷键&#xff0c;导致你按了之后电脑不知道该响应哪个软件。 解决办法&#xff1a;1.将当前软件的这个快捷键改了&#xff1b;2.找到占用的那个软件&#xff0c;把那…

springboot404-基于Java的校园礼服租赁系统(源码+数据库+纯前后端分离+部署讲解等)

&#x1f495;&#x1f495;作者&#xff1a; 爱笑学姐 &#x1f495;&#x1f495;个人简介&#xff1a;十年Java&#xff0c;Python美女程序员一枚&#xff0c;精通计算机专业前后端各类框架。 &#x1f495;&#x1f495;各类成品Java毕设 。javaweb&#xff0c;ssm&#xf…

PHP支付宝--转账到支付宝账户

官方参考文档&#xff1a; ​https://opendocs.alipay.com/open/62987723_alipay.fund.trans.uni.transfer?sceneca56bca529e64125a2786703c6192d41&pathHash66064890​ 可以使用默认应用&#xff0c;也可以自建新应用&#xff0c;此处以默认应用来讲解【默认应用默认支持…

推荐一款AI大模型托管平台-OpenWebUI

推荐一款AI大模型托管平台-OpenWebUI 1. OpenWebUI 1. OpenWebUI什么? 官网地址&#xff1a;https://openwebui.com/ GitHub地址&#xff1a; https://github.com/open-webui/open-webui Open WebUI 是一个可扩展、功能丰富且用户友好的自托管 AI 平台&#xff0c;旨在完全离…

代码随想录D50-51 图论 Python

理论基础 理论基础部分依然沿用代码随想录教程中的介绍&#xff1a; 图的种类 度 连通性 连通性用于表示图中节点的连通情况。 如果有节点不能到达其他节点&#xff0c;则为非连通图&#xff0c;想象将多个水分子表示为图&#xff0c;不考虑非键作用&#xff0c;这张图就不是…

Mac M3/M4 本地部署Deepseek并集成vscode

Mac 部署 使用傻瓜集成平台ollama&#xff0c;ollama平台依赖于docker&#xff0c;Mac的M3/M4 因doesn’t have VT-X/AMD-v enabled 所以VB,VM无法使用&#xff0c;导致docker无法启动&#xff0c;需要使用docker的替代品podman&#xff0c; 它完全兼容docker brew install p…

TikTok账户安全指南:如何取消两步验证?

TikTok账户安全指南&#xff1a;如何取消两步验证&#xff1f; 在这个数字化的时代&#xff0c;保护我们的在线账户安全变得尤为重要。TikTok&#xff0c;作为全球流行的社交媒体平台&#xff0c;其账户安全更是不容忽视。两步验证作为一种增强账户安全性的措施&#xff0c;虽…

【C++复习专题】—— 类和对象,包含类的引入、访问限定符、类的6个默认成员函数等

1.类的定义 class classname {//类体&#xff1a;由成员函数和成员变量组成 }; class为定义类的关键字&#xff0c;classname为类的名字&#xff0c;{}中为类的主体。 类体中的内容称为类的成员&#xff1a;类中的变量称为类的属性或成员变量&#xff1b;类中的函数称为类的方…

Spring--BeanDefinition的用法

原文网址&#xff1a;Spring--BeanDefinition的用法_IT利刃出鞘的博客-CSDN博客 简介 本文介绍BeanDefinition的用法。 BeanDefinition是Bean的信息&#xff0c;用于生成Bean。 示例&#xff1a;手动注册Bean 待填充 BeanDefinition的作用 get 下图是通过beanDefinitio…

关于C#的一些基础知识点汇总

1.C#结构体可以继承接口吗&#xff1f;会不会产生GC&#xff1f; 在 C# 中&#xff0c;结构体不能继承类&#xff0c;但可以实现接口。 代码&#xff1a; interface IMyInterface {void MyMethod(); }struct MyStruct : IMyInterface {public void MyMethod(){Console.Write…

一文讲解Redis为什么读写性能高以及I/O复用相关知识点

Redis为什么读写性能高呢&#xff1f; Redis 的速度⾮常快&#xff0c;单机的 Redis 就可以⽀撑每秒十几万的并发&#xff0c;性能是 MySQL 的⼏⼗倍。原因主要有⼏点&#xff1a; ①、基于内存的数据存储&#xff0c;Redis 将数据存储在内存当中&#xff0c;使得数据的读写操…

Hadoop-HA(高可用)机制

首先&#xff1a;在每个NAMENODE上都会有一个zkfc&#xff08;zookeeper failover colltroller&#xff09; &#xff0c;负责这两个的状态管理。哪个是&#xff08;active和standby&#xff09;然后写入zk集群里面。同时监控自己所在的机器是否正常。一旦active上zkfc的发现异…

51单片机-按键

1、独立按键 1.1、按键介绍 轻触开关是一种电子开关&#xff0c;使用时&#xff0c;轻轻按开关按钮就可使开关接通&#xff0c;当松开手时&#xff0c;开关断开。 1.2、独立按键原理 按键在闭合和断开时&#xff0c;触点会存在抖动现象。P2\P3\P1都是准双向IO口&#xff0c;…

深度学习的力量:精准肿瘤检测从此不再遥远

目录 引言 一、医学图像分析的挑战与深度学习的优势 1.1 医学图像分析的挑战 1.2 深度学习的优势 二、肿瘤检测的深度学习模型设计 2.1 卷积神经网络&#xff08;CNN&#xff09;的基本原理 2.2 网络架构设计 2.3 模型训练 三、肿瘤检测中的挑战与解决方案 3.1 数据不…

初尝git自结命令大全与需要理解的地方记录

常用命令 git init–初始化工作区touch 文件全称–在工作区创建文档rm 文件全称 --删除文档notepad 文件全称–在工作区打开文档cat 文件全称–在显示框显示文档的东西git status --显示工作区的文件冲突的文件 &#xff08;git add 文件全称或者.&#xff09; —将工作区文件…

LangChain 技术入门指南:探索语言模型的无限可能

在当今的技术领域&#xff0c;LangChain 正逐渐崭露头角&#xff0c;成为开发语言模型应用的强大工具。如果你渴望深入了解并掌握这一技术&#xff0c;那么就跟随本文一起开启 LangChain 的入门之旅吧&#xff01; (后续将持续输出关于LangChain的技术文章,有兴趣的同学可以关注…

Pycharm+CodeGPT+Ollama+Deepseek

首先&#xff0c;体验截图&#xff1a; 接着&#xff1a; 1、下载Ollama&#xff1a; Download Ollama on macOS 2、下载模型 以1.5b为例&#xff0c;打开命令行&#xff0c;输入: ollama run deepseek-r1:1.5b 3、Pycharm安装Code GPT插件 打开PyCharm&#xff0c;找到文…

阿里云k8s服务部署操作一指禅

文章目录 DockerFile镜像操作阿里云k8s服务部署 DockerFile # 使用 JDK 17 官方镜像 # linux架构&#xff1a;FROM --platformlinux/amd64 openjdk:17-jdk-slim # arm架构&#xff1a;openjdk:17-jdk-slim FROM --platformlinux/amd64 openjdk:17-jdk-slim# 设置工作目录 WORK…

.NET + Vue3 的前后端项目在IIS的发布

目录 一、发布准备 1、安装 IIS 2、安装 Windows Hosting Bundle&#xff08;.NET Core 托管捆绑包&#xff09; 3、安装 IIS URL Rewrite 二、项目发布 1、后端项目发布 2、前端项目发布 3、将项目部署到 IIS中 三、网站配置 1、IP配置 2、防火墙配置 3、跨域配置…