python read函数报错_Python实现word_count

Github链接: https://github.com/dududu7/wc_project

1. PSP2.1表格

PSP2.1

Personal Software Process Stages

预估耗时(分钟)

实际耗时(分钟)

Planning

计划

10

20

· Estimate

· 估计这个任务需要多少时间

10

15

Development

开发

300

550

· Analysis

· 需求分析 (包括学习新技术)

200

300

· Design Spec

· 生成设计文档

10

20

· Design Review

· 设计复审 (和同事审核设计文档)

0

0

· Coding Standard

· 代码规范 (为目前的开发制定合适的规范)

10

10

· Design

· 具体设计

20

100

· Coding

· 具体编码

300

200

· Code Review

· 代码复审

10

10

· Test

· 测试(自我测试,修改代码,提交修改)

60

180

Reporting

报告

30

30

· Test Report

· 测试报告

30

10

· Size Measurement

· 计算工作量

10

10

· Postmortem & Process Improvement Plan

· 事后总结, 并提出过程改进计划

10

30

合计

1100

1485

项目相关要求

基本功能

-c file.c 返回文件file.c的字符数 (实现)

-w file.c 返回文件file.c的词的数目(实现)

-l file.c 返回文件file.c的行数(实现)

扩展功能

-s 递归处理目录下符合条件的文件(实现)

-a 返回更复杂的数据(代码行 / 空行 / 注释行)(实现)

高级功能

-x 程序会显示图形界面,用户可以通过界面选取单个文件,程序就会显示文件的字符数、行数等全部统计信息。(未实现)

解题思路

首先把大问题拆分成几个函数功能去实现:读取文件read();数基本功能的数目count_cl();数扩展功能的行数count_w();输出print1();递归文件duigui()这几大块;后来因为具体实现与一开始计划有出入,又增加了函数find(),而且基本功能和扩展的函数也有了变化。

这个题目有几个地方我实现了很久,首先是基础功能的返回word,对于怎样区分出单词有些困惑。因为主体是区分.py的代码-a的时候,也是考虑‘’‘   ’‘’和#为主的注释行,递归的是子文件的内容,搞清楚目的操作并没有太复杂。 Py相比于C和JAVA更面向对象,而且最近对Python感兴趣想要挑战一下自己,所以选择了开发效率较高的python。由于以前从来没有开发过使用命令行参数启动的程序,最后还是用input的方法进行输入。

设计实现过程和代码说明

首先实现基础功能,读取文件:

e9a6603425b225e0a508b25ed6d93c04.png

#比起Re = open(dict1[numble])之后close文件要好,逐行读取

be4db715af675ee62920e11fd3ca342d.png

逐行读取的好处:-a 容易实现,readline后很容易计算空行,代码行

调用find函数,返回所有出现‘’’   ‘’’ 的行数,以便之后计算注释行数量

1d66968310b28ae4204b8c09c71537ee.png

963a74971027a7ed8ad82618ad91c6d8.png

输出函数print1(),和read函数

828910cefabb3f3ca322912f9f35e24d.png

为了实现递归读取,需要解决以下几个问题:1.b2f4d25cb3513ef5b59b8e194d4af267.png

为了处理读取path中\转义报错的问题,一开始采取前面加r的方式,但是路径不能input:84ac60db9e415c6989b539d0af63ca48.png

查找解决方法时看到:转义只发生在代码字面量转换为python内部对象的过程中。已经是字符串了,则不会再次转义。

所以只要在转义之后再改回来就好:

f976950c8c2d828046890b95e5f69907.png

2.递归的时候只会加文件不会加'\',要记得加上‘\’符号

3.路径错误->报错

2f983111b7da613b22daab584ee2c930.png

main函数:

4109779a2dd468b411232e52a38253d9.png

转py为exe文件,可以先下一个pyInstall,百度过程就好

30ea94f43accce86c114c667b88be8fe.png

ba73f9d89376bcbd4beaae45f84c5379.png

这样就算转换成功了。

测试:

·文件测试:

1.空文件

d1e8893dfc90f18daef280f86f103680.png

71478823c9b639a38f928f741931737c.png

3.1个字符

1e53ba743019b3e9d8998647858569a1.png

bc7c2a67d873ed4bb83bec11d8957c45.png

这里回车也算作了1个字符

3.1个单词

453198cf2ba5c5cb7b3e6f5254407b5a.png

80147a1ab645c71ac7c2f3d69c3299db.png

4.完整代码

9a2068495bf77359e803f9c639aadcbb.png

86c2a4b9cb4816372de67fe0f8bf3eef.png

单独打印word:

e8dfb5341ab206cc5b8c36092fe149b1.png

·递归测试:

5efa41df7c2ebe3f8f9f813b88cb720e.png

002cd3867c0aa4d91692d09f4eed7fee.png

ea7de0a6172cf818d1dd490af58eb1c0.png

项目总结:

完成这个项目耗时挺久,现在能完全理解那句写功能只要20%的时间,接下来都在改bug了。虽然在暑假学习过Python,但是不够系统,导致我写代码的时候要不停的搜索,查找资料,之前的IDLE让我常常有缩进的错误,换成Pycharm才更顺手。有的时候卡bug卡半天不能解决,有的时候学习正则表达式等等用时良久,不过最终还是在星期五测试成功了。但是由于一直东拼西凑,还有很多可以改进的地方,比如输入可以更精简而不是多加一个-h解决输入全部的问题,比如读取文件read最好一次就行了,或者是功能写的更清晰一些。写代码的时候不自觉的带了好多目录,之前写C的时候习惯这样了,不知道算不算画蛇添足。这次累计的经验我会好好从中学习,争取下一次做的更好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值