代码拼写检查器 JAVA

2024-03-20 00:52
文章标签 java 代码 检查 拼写

本文主要是介绍代码拼写检查器 JAVA,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

蓝桥杯物联网竞赛有一些接口函数需要自己去配置,所以接口函数不能出现严重的编写错误,所以每次默写都需要严格检查自己所写的接口函数是否能运形成功,检查过程十分繁琐,想通过程序来帮助检查,所以用Java写了检查函数,主要检查拼写,和一些必要的格式。

忽略部分:

1、忽略上下语句之间的空行数量

2、忽略两个关键字之间的空格数量

3、可忽略也可关注关键字之间大小写的区别

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;public class Main {public static void main(String[] args) {// 设置D盘文件的路径String TrueFilePath = "C:\\Users\\12654\\Desktop\\TrueProcedure.txt.txt"; String MyFilePath = "C:\\Users\\12654\\Desktop\\MyProcedure.txt.txt";// 存储读取到的单词List<String> Truelines = new ArrayList<>();  // 模板List<String> Mylines = new ArrayList<>();  // 我的代码try {// 读取模板代码FileReader TruefileReader = new FileReader(TrueFilePath);BufferedReader bufferedTrueReader = new BufferedReader(TruefileReader);// 读取我的代码FileReader MyfileReader = new FileReader(MyFilePath);BufferedReader bufferedMyReader = new BufferedReader(MyfileReader);String lineTrue;String lineMy;// 逐行读取while (((lineTrue = bufferedTrueReader.readLine()) != null) | ((lineMy = bufferedMyReader.readLine()) != null)) {// 去除行首的空格if(lineTrue != null) {String trimmedLine1 = lineTrue.trim();// 将处理后的行添加到列表中Truelines.add(trimmedLine1);}// 去除行首的空格if(lineMy != null) {String trimmedLine2 = lineMy.trim();// 将处理后的行添加到列表中Mylines.add(trimmedLine2);}}// 关闭资源bufferedTrueReader.close();TruefileReader.close();bufferedMyReader.close();MyfileReader.close();} catch (IOException e) {e.printStackTrace();}// 输出读取到的处理后的行System.out.println(TextCheck(Truelines, Mylines, "null")); // case不在乎大小写,其他都是在乎}public static String TextCheck(List<String> Truelines, List<String> Mylines, String ask) {int cas = 0;if(ask.equals("case")) cas = 1;  //是否在乎大小写 Iterator<String> iterator1 = Truelines.iterator();Iterator<String> iterator2 = Mylines.iterator();int linenumber = 1;String checkstring = "";String TrueLine = "", MyLine = "";int i = 0;while(iterator1.hasNext() || iterator2.hasNext()) {  // 都空推出/* 解决谁先被读完问题 */if(!iterator1.hasNext()) { // 到末尾if(iterator2.hasNext()) MyLine = iterator2.next();  // 过掉相同一行while(MyLine.equals("") && iterator2.hasNext()) MyLine = iterator2.next();  //看看多出部分是不是空行if(!MyLine.equals("")) //仍有多余return "位置: (" + linenumber + ", " +"MuchError!)" + "\r\n" + "你的: " + MyLine;break;}if(!iterator2.hasNext()) { // 到末尾if(iterator1.hasNext()) TrueLine = iterator1.next();  // 过掉相同一行while(TrueLine.equals("") && iterator1.hasNext()) TrueLine = iterator1.next();if(!TrueLine.equals("")) //仍有多余return "位置: (" + linenumber + ", " +"LessError!)" + "\r\n" + "标准: " + TrueLine;break;}i ++;System.out.println(i);/* 解决中间有多余空行问题 */// 有空行就一直跳直到不是空行或者最后位置MyLine = iterator2.next();while(MyLine.equals("") && iterator2.hasNext()) MyLine = iterator2.next();  // 解决两个语句之间多空行的问题TrueLine = iterator1.next();while(TrueLine.equals("") && iterator1.hasNext()) TrueLine = iterator1.next();   // 后面还有数据if((checkstring = Check(TrueLine, MyLine, cas)) != null) {return "位置: (" + linenumber + ", " + checkstring + "\r\n" + "标准: " + TrueLine + "\r\n" + "你的: " +MyLine;}linenumber ++;}return "BinGo!";}public static String Check(String True, String My, int cas) {  // 比较函数String t[] = True.split("\\s+");String m[] = My.split("\\s+");//String tt = "", mm = "";if(t.length != m.length) return "LengthError!)";for(int i = 0; i < t.length; i ++) {//tt = t[i]; mm = m[i];t[i] = Capit(t[i], cas);m[i] = Capit(m[i], cas);if(!t[i].equals(m[i])) return "" + (i + 1) + ")";}return null;}public static String Capit(String word, int cas) {  // 大写函数if(cas != 1) return word;String NewWord = "";for(char arr : word.toCharArray()) {if(arr >= 'a' && arr <= 'z') NewWord = NewWord + (char)(arr - 32);else NewWord = NewWord + arr;}return NewWord;}
}

这篇关于代码拼写检查器 JAVA的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来