本文实例讲述了python去除文件中空格、Tab及回车的方法。分享给大家供大家参考,具体如下:
在最近的开发工作中,为了应付比赛赶进度,服务端的json文件都是人工写的,写完之后发现格式都是十分规整,易于人阅读的json,但是客户端请求不需要那些为了格式而在json里面添加的空格、tab、回车等等没用的字符,遂用python写一脚本,去除文件中的空格、回车、换行。
原json文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
{ "amount" : "2" , "content" : [ { "category_id" : 0, "name" : "古典文学" , "category_json_url" : "http://172.16.242.14:8080/source/history/history.json" } , { "category_id" : 1, "name" : "流行音乐" , "category_json_url" : "http://172.16.242.14:8080/source//popmusic/popmusic.json" } ] } |
用脚本处理后的文件:
复制代码 代码如下:
{"amount":"2","content":[{"category_id":0,"name":"古典文学","category_json_url":"http://172.16.242.14:8080/source/history/history.json"},{"category_id":1,"name":"流行音乐","category_json_url":"http://172.16.242.14:8080/source//popmusic/popmusic.json"}]}
下面上代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
def stripFile(oldFName,newFName): '''''remove the space or Tab or enter in a file,and output to a new file in the same folder''' fp = open (oldFName, "r+" ) newFp = open (newFName, "w" ) for eachline in fp.readlines(): newStr = eachline.replace( " " ," ").replace(" \t "," ").strip() #print "Write:",newStr newFp.write(newStr) fp.close() newFp.close() if __name__ = = "__main__" : oldName = raw_input ( "input file name:" ) nameList = oldName.split( "." ) newName = "%s%s%s" % (nameList[ 0 ], "_new." ,nameList[ 1 ]) stripFile(oldName,newName) print "finish output to new file:" ,newName |
使用脚本时,如果脚本文件和要处理的文件在同一目录下,则直接输入文件名,如果不在,需要输入文件的完整路径。
记得听Cliff说过,程序员就要有一个批量处理的意识,要学会发挥机器的力量,感觉还是很对的。
希望本文所述对大家Python程序设计有所帮助。