背单词工具

2024-03-22 03:59
文章标签 工具 背单词

本文主要是介绍背单词工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背单词工具

由于前段时间埋下的每天背十个单词的坑,所以有了这篇的文章。
工欲善其事必先利其器,背单词之前肯定需要有一个好工具。
虽然已经有好多成熟的背单词的app了,但是秉承着不用自己写的工具背单词的程序员不是好保安的原则。
那咱就自己写一个背单词的工具,你别管好不好用,我就乐意写。(●ˇ∀ˇ●)


推荐一个单词网站

单词网站

测试效果

在这里插入图片描述

在这里插入图片描述

准备工作

将单词学习笔记记录到markdown文本中

# 英语学习笔记## 2023-09-07
___**species**n.种,物种,种类例句:
1. This species is extremely rare. 这一物种极为罕见
2. Panadas are an endangered species. 大熊猫是一种濒危物种
3. There are many species of dog(s). 狗有许多种类
4. At least one otter species,the sea otter,has a large,often dominating,effect on the structure of its own habitat**explanation**adj.说明,解释,辩解例句:
1. There was a logical explanation. 存在一个合理的解释
2. I think you owe us an explanation. 我认为你应当给我们一个解释
3. He didn't get a decent explanation. 他没有得到一个合理的解释**significant**adj.重大的;有效的;有意义的;值得注意的例句:
1. There remained one significant problem. 还有一个非常重要的问题
2. Your work has shown a significant improvement. 你的工作有了显著的改进
3. The result are not statistically significant. 这些结果在统计上没有显著意义**traditional**adj.传统的;惯例的;例句:
1. Most bosses are traditional. 大多数老板都很传统
2. Traditional values have been reasserted. 传统价值再次得到肯定
3. Most couples want a traditional wedding. 多数情侣希望举办一个传统的婚礼**evidence**n.证据,证明;迹象;明显
vt.证明例句:
1. The evidence is against him. 证据对他不利
2. I had no concrete evidence. 我当时没有明确而具体的证据
3. Evidence is plentifully available. 证据俯拾即是**temperature**n.温度;体温;气温;发烧例句:
1. Her temperature is normal. 她的体温正常
2. The temperature is plus four degrees. 温度为零上四度
3. The temperature has dropped considerably. 温度已大大降低

开始写代码

直接贴代码,将上面的单词markdown笔记放在resource目录中,将markdown读取到内存中解析。

解析markdown前,我们先分析一下markdown的规范,有规范才能解析。

  1. 英语单词是用** **包括着的
  2. 英语翻译是用 “adj”, “n”, “vt”, “v”, “vi”,“adv”,“prep” 前缀开头的,并且翻译有可能多个,没有包括所有的单词类型,后续有新的单词类型需要加上
  3. 例句是由 数字 开头的后几行

有了这几个规范我们就可以开始解析了。

先定义一个WordItem内部对象,用于接收单词数据。

@Data
static class WordItem {private String wordCn;private String wordEng;private List<String> exampleSentenceList;
}

逐行解析,从第一个单词到下一个单词前结束,将这段范围的内容封装成一个WordItem对象。

接下来就直接看代码吧,注释会写清楚的。


package com.tfxing.persondaily.utils;import cn.hutool.core.collection.CollectionUtil;
import lombok.Data;import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.math.BigDecimal;
import java.util.*;public class WordExamPlusUtils {@Datastatic class WordItem {private String wordCn;private String wordEng;private List<String> exampleSentenceList;}private List<Integer> numbers;private Random random;private Map<String,WordItem> wordMap;private List<String> keyList;private Boolean isEnd = false;public WordExamPlusUtils() {numbers = new ArrayList<>();random = new Random();wordMap = new HashMap<>();keyList = new ArrayList<>();// 匹配翻译的前缀List<String> wordCnPrefixList = Arrays.asList("adj", "n", "vt", "v", "vi","adv","prep");// 指定Markdown文件的路径String filePath = "src/main/resources/EnglishStudy.md";WordItem wordItem = null;// 用于接收单词翻译,多个翻译使用换行号分隔,打印时会直接换行StringJoiner wordCn = new StringJoiner("\n");// 例句列表List<String> exampleSentenceList = new ArrayList<>();try {// 创建一个BufferedReader来读取文件BufferedReader reader = new BufferedReader(new FileReader(filePath));String line;// 逐行读取文件内容并打印到控制台while ((line = reader.readLine()) != null) {if(skip(line)) { // 不符合前面梳理的规范的行直接跳过continue;}// **开头的是英语单词,isEnd在遇到第一个单词时设置为了true,所以第二个单词后会走这个if的逻辑。将封装好的WordItem对象添加到wordMap中if(line.startsWith("**") && isEnd) {String wordCnStr = wordCn.toString();wordItem.setWordCn(wordCn.toString());wordItem.setExampleSentenceList(exampleSentenceList);wordMap.put(wordCnStr, wordItem);keyList.add(wordCnStr);wordCn = new StringJoiner("\n");exampleSentenceList = new ArrayList<>();wordItem = new WordItem();String wordEng = line.replaceAll("\\*","");wordItem.setWordEng(wordEng);continue;}// 遇到第一个单词,将WordItem实例化,并设置英语单词的值if (line.startsWith("**")) {wordItem = new WordItem();String wordEng = line.replaceAll("\\*","");wordItem.setWordEng(wordEng);// 遇到第一个单词后,将isEnd设置为trueisEnd = true;}// 将翻译加到wordCn中if(containsWordPrefix(line,wordCnPrefixList)) {wordCn.add(line);}// 数字开头的是翻译,将翻译添加到列表中if(isNumPrefix(line)) {exampleSentenceList.add(line);}}// 关闭文件流reader.close();} catch (IOException e) {e.printStackTrace();} finally {// 最后的单词没有下一个单词结束,所以在finally中处理最后一个单词的封装。String wordCnStr = wordCn.toString();wordItem.setWordCn(wordCn.toString());wordItem.setExampleSentenceList(exampleSentenceList);wordMap.put(wordCnStr, wordItem);keyList.add(wordCnStr);// 初始化数字列表,每个数字出现2次for (int i = 0; i < keyList.size(); i++) {numbers.add(i);numbers.add(i);}}}/*** 是否以数字.开头* @param line* @return*/private boolean isNumPrefix(String line) {return line.matches("^\\d+\\..*");}/*** 以预设开头匹配* @param line* @param wordCnPrefixList* @return*/private boolean containsWordPrefix(String line, List<String> wordCnPrefixList) {if(CollectionUtil.isEmpty(wordCnPrefixList)) {return false;}for (String wordCnPrefix : wordCnPrefixList) {if(line.startsWith(wordCnPrefix)) {return true;}}return false;}private boolean skip(String line) {return StringUtils.isBlank(line) ||line.startsWith("#") ||line.startsWith("_") ||line.startsWith("例句");}public Integer size() {return keyList.size();}public Integer roundSize() {return numbers.size();}public WordItem exam() {Integer index = getNextRandomNumber();if(Integer.valueOf(-1).equals(index)) {return null;}String key = keyList.get(index);WordItem wordItem = wordMap.get(key);return wordItem;}public int getNextRandomNumber() {if (numbers.isEmpty()) {return -1;}// 从数字列表中随机选择一个数字int randomIndex = random.nextInt(numbers.size());int randomNumber = numbers.get(randomIndex);// 从数字列表中移除已经被选中的数字numbers.remove(randomIndex);return randomNumber;}// 测试public static void main(String[] args) {WordExamPlusUtils wordExamUtils = new WordExamPlusUtils();Scanner scanner = new Scanner(System.in);Integer roundSize = wordExamUtils.roundSize();Integer total = roundSize;List<String> errorWordList = new ArrayList<>();while(roundSize > 0) {WordItem exam = wordExamUtils.exam();System.out.println(exam.getWordCn());System.out.println("请输入:");String input = scanner.next();if(exam.getWordEng().equalsIgnoreCase(input)) {System.out.println("正确");} else {System.out.println("错误");System.out.println(exam.getWordEng());errorWordList.add(exam.getWordCn() + " : " + exam.getWordEng());}for (String exampleSentence : exam.getExampleSentenceList()) {System.out.println(exampleSentence);}System.out.println();roundSize --;}int errorSize = errorWordList.size();int successSize = total - errorSize;BigDecimal rate = BigDecimal.valueOf(successSize).divide(BigDecimal.valueOf(total), 2, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100));System.out.println("本次测试,一共测试了" + total + "个单词\n正确个数:" + successSize + "\n错误个数:" + errorSize + "\n" + "正确率为:" + rate + "%");System.out.println();for (String errorWord : errorWordList) {System.out.println(errorWord);}}
}

一小段没有意义的话

写好了工具总算是可以认真背单词了吧。
。。。
不出意外的出意外是我的常态。
坚持了三天,背了三十个单词后,突然来了一个很复杂的需求。。。
时间给的也太紧了吧。我还要背单词呢。
看来只能先放一放了,虽然我有崇高的理想与追求。
但是生活不易,打工人还是得老老实实的打工才行啊。/(ㄒoㄒ)/~~

这篇关于背单词工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/834471

相关文章

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

基于Python实现简易视频剪辑工具

《基于Python实现简易视频剪辑工具》这篇文章主要为大家详细介绍了如何用Python打造一个功能完备的简易视频剪辑工具,包括视频文件导入与格式转换,基础剪辑操作,音频处理等功能,感兴趣的小伙伴可以了... 目录一、技术选型与环境搭建二、核心功能模块实现1. 视频基础操作2. 音频处理3. 特效与转场三、高

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核