wc.java
1.项目相关要求
•基本功能列表:
-c 统计文件中字符的个数
-w 统计文件中的词数
-l 统计文件中的行数
•拓展功能:
-a 统计文件中代码行数、注释行数、空行
2.PSP2.1
|
PSP2.1 |
Personal Software Process Stages |
预估耗时(小时) |
实际耗时(小时) |
|
Planning |
计划 |
1.0 | 1.5 |
|
· Estimate |
· 估计这个任务需要多少时间 |
0.5 | 1 |
|
Development |
开发 |
30 | 40 |
|
· Analysis |
· 需求分析 (包括学习新技术) |
0.5 | 1 |
|
· Design Spec |
· 生成设计文档 |
0.5 | 0.6 |
|
· Design Review |
· 设计复审 (和同事审核设计文档) |
0.5 | 0.2 |
|
· Coding Standard |
· 代码规范 (为目前的开发制定合适的规范) |
0.5 | 0.5 |
|
· Design |
· 具体设计 |
1 | 1.5 |
|
· Coding |
· 具体编码 |
30 | 40 |
|
· Code Review |
· 代码复审 |
1 | 2 |
|
· Test |
· 测试(自我测试,修改代码,提交修改) |
0.5 | 1 |
|
Reporting |
报告 |
0.5 | 0.5 |
|
· Test Report |
· 测试报告 |
0.5 | 0.5 |
|
· Size Measurement |
· 计算工作量 |
0.5 | 0.5 |
|
· Postmortem & Process Improvement Plan |
· 事后总结, 并提出过程改进计划 |
0.5 | 1 |
|
合计 |
39 | 52 |
3.解题思路
首先需要读取文件,然后通过命令 计算出字符、词、行、空行、注释行、代码行。
基础功能部分:读取文件后,将读取的文件转换成数组的形式,然后每生成一个数组,就是一行。其中,数组的长度就是字符数。利用正则表达式,判断词的开头结尾,进行计数。
拓展功能部分:利用正则表达式判断是否是注释行。数组长度为0或1为空行。然后代码行=总行数-空行-注释行
4.流程图

5.代码实现
字符数
public static void charNum()throws Exception
{ //文件导入
Scanner input = new Scanner(System.in);
System.out.println("please input path:");
String path = input.next();
int countChar = 0;
InputStreamReader isr = new InputStreamReader(new FileInputStream(path));
BufferedReader br = new BufferedReader(isr); while(br.read()!=-1)//read()=-1代表数据读取完毕
{
String s = br.readLine(); countChar += s.length();//字符个数就是字符长度
} isr.close();//关闭文件
System.out.println("字符个数 "+countChar); }
词数
public static void wordNum()throws Exception
{Scanner input = new Scanner(System.in);
System.out.println("please input path:");
String path = input.next();
int countword = 0;
InputStreamReader isr = new InputStreamReader(new FileInputStream(path));
BufferedReader br = new BufferedReader(isr);
while(br.read()!=-1)//read()=-1代表数据读取完毕
{
String s = br.readLine();
Pattern p = Pattern.compile("\\b[A-Za-z]+\\b");//创建以字母为开头或结尾的模板
Matcher m = p.matcher(s.toString());
while(m.find())
{
countword++;
} } isr.close();//关闭文件 System.out.println("单词个数 "+countword );
行数
public static void lineNum()throws Exception
{Scanner input = new Scanner(System.in);
System.out.println("please input path:");
String path = input.next();
int countline = 0;
int countcommentline = 0;
InputStreamReader isr = new InputStreamReader(new FileInputStream(path));
BufferedReader br = new BufferedReader(isr);
while(br.read()!=-1)//read()=-1代表数据读取完毕
{
String s = br.readLine();
countline++;//因为是按行读取,所以每次增加一即可计算出行的数目
}
isr.close();//关闭文件
System.out.println("行数 "+countline); }
空行,注释行,代码行
public static void alllineNum()throws Exception
{Scanner input = new Scanner(System.in);
System.out.println("please input path:");
String path = input.next();
int countline = 0;
int countcommentline = 0;
int countblankline = 0;
int codeNum=0;
InputStreamReader isr = new InputStreamReader(new FileInputStream(path));
BufferedReader br = new BufferedReader(isr);
while(br.read()!=-1)//read()=-1代表数据读取完毕
{
String s = br.readLine();
if(s.length()<=1)
{
countblankline++;
}
Pattern p = Pattern.compile("((/)|(/\\*+)|((^\\s)*\\*)|((^\\s)*\\*+/))+");//创建以注释符为开头或结尾的模板 Matcher m = p.matcher(s.toString());
while(m.find())
{
countcommentline++;
}
countline++;//因为是按行读取,所以每次增加一即可计算出行的数目
}
isr.close();//关闭文件
codeNum=countline-countcommentline-countblankline;
System.out.println("行数 "+countline);
System.out.println("注释行 "+countcommentline );
System.out.println("空行数 "+countblankline);
System.out.println("代码行 "+codeNum);
}
main函数
public static void main(String[] args) throws Exception
{ String bString = null;
System.out.println("请输入命令 ");
Scanner ms= new Scanner(System.in);
if (ms.hasNext()) {
bString = ms.next();
}
if (bString.equals("-c"))
{
s.charNum();
}
if (bString.equals("-w"))
{
s.wordNum();
}
if (bString.equals("-l"))
{
s.lineNum();
}
if (bString.equals("-b"))
{
s.blanklineNum(); }
if (bString.equals("-a"))
{
s.alllineNum(); } }
6.测试运行

7. 项目总结
通过这次项目,我发现自己知识体系有所欠缺,通过学习书本,和上网查询,请教同学得以解决。也学习到了许多新的知识。
wc.java的更多相关文章
- 个人项目-WC (java实现)
一.Github地址:https://github.com/734635746/WC 二.PSP表格 PSP2.1 Personal Software Process Stages 预估耗时(分钟) ...
- 个人项目 wc(java实现)
一.Github网址: https://github.com/Clarazhangbw/Wc.exe 二.PSP表 PSP2.1 Personal Software Process Stages 预估 ...
- WC Java 实现
项目 github 地址 一. 实现情况 基本要求 c 统计文件字符数 (实现) w 统计文件词数 (实现) l 统计文件行数(实现) 扩展功能 s 递归处理目录下符合条件得文件(实现) a 返回文件 ...
- 个人项目:Java实现WC
Java实现WC Github项目地址:https://github.com/auxshaw/WC 项目要求 wc.exe 是一个常见的工具,它能统计文本文件的字符数.单词数和行数.这个项目要求写一个 ...
- (https://www.ibm.com/developerworks/community/forums/html/topic?id=77777777-0000-0000-0000-000014550004)Topic: Caught java.io.CharConversionException. ERRORCODE=-4220, SQLSTATE=null
270002WDPN 3 Posts 0 people l ...
- 本地idea开发mapreduce程序提交到远程hadoop集群执行
https://www.codetd.com/article/664330 https://blog.csdn.net/dream_an/article/details/84342770 通过idea ...
- HUST软测1504班第2周作业成绩:WordCount
说明 本次公布的成绩为第2周个人作业WordCount的结果: 第2周个人作业:WordCount 如果同学对作业结果存在异议,可以: 在毕博平台讨论区的第2周作业第在线答疑区发帖申诉. 或直接在博客 ...
- Spark案例分析
一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...
- 小白のjava实现wc.exe功能
GitHub地址 项目完成情况 基本功能列表(已实现) wc.exe -c file.c //返回文件 file.c 的字符数 wc.exe -w file.c //返回文件 file. ...
随机推荐
- 大型运输行业实战_day10_1_自定义事务管理类
1.创建事务管理类 TransactionManager.java package com.day02.sation.transaction; import com.day02.sation.uti ...
- Array Product(模拟)
Array Product http://codeforces.com/problemset/problem/1042/C You are given an array aa consisting o ...
- Java中spring读取配置文件的几种方法
Spring读取配置XML文件分三步: 一.新建一个Java Bean: package springdemo; public class HelloBean { private String hel ...
- ViewPager欢迎界面
一.几张图片组成欢迎界面 下方有几个点对应每个图片 当图片被选中时对应的点会变亮,当对应的点被点击时也会切换到指定画面 以下是代码 package com.example.viewpager_1; i ...
- How to set an Apache Kafka multi node – multi broker cluster【z】
Set a multi node Apache ZooKeeper cluster On every node of the cluster add the following lines to th ...
- Python Socket 编程详细介绍(转)
Python 提供了两个基本的 socket 模块: Socket 它提供了标准的BSD Socket API. SocketServer 它提供了服务器重心,可以简化网络服务器的开发. 下面讲解下 ...
- DB2与oracle类型对比
本文摘自http://www.cnblogs.com/cy163/archive/2010/11/17/1880280.html 做过DB2数据库应用迁移的工程师,了解IBM MTK工具在迁移过程中所 ...
- TPM、read counts、RPKM/FPKM你选对了吗?
TPM.read counts.RPKM/FPKM你选对了吗? 已有 3940 次阅读 2017-12-15 15:04 |个人分类:RNA-seq|系统分类:科普集锦|关键词:RNA-seq| RN ...
- Debian Buster 配置 Laravel 运行环境(nginx + redis + supervisor)
1 目标 将开发完成的 Laravel 项目布署于 Debian 之上.由于项目要求使用 horizon 官方扩展,要求 PHP7.1+,故采用 Debian buster (下一版) 2 材料 IP ...
- Java数据结构和算法(一)概念
Java数据结构和算法(一)概念 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 一.逻辑结构 数据之间的相互关系称为逻辑结构 ...