码迷,mamicode.com
首页 > 编程语言 > 详细

用python 实现linux 的wc 命令

时间:2016-10-10 02:10:44      阅读:273      评论:0      收藏:0      [点我收藏+]

标签:python   wc   

#!/usr/bin/env python

"""file name: opt_wc.py"""
 
import os
import sys
from optparse import OptionParser
 
def opt():
    parser = OptionParser()
 
    parser.add_option("-c", "--chars",
                      dest = "chars",
                      action = "store_true",
                      default = False,
                      help = "only count chars.")
    parser.add_option("-w", "--words",
                      dest = "words",
                      action = "store_true",
                      default = False,
                      help = "only count words.")
    parser.add_option("-l", "--lines",
                      dest = "lines",
                      action = "store_true",
                      default = False,
                      help = "only count lines.")
    options, args = parser.parse_args()
 
    return options, args
 
def get_Count(data):
    chars = len(data)
    words = len(data.split())
    lines = data.count(‘\n‘)
    return lines, words, chars
 
def print_wc(options, lines, words, chars, fn):
    if options.lines:
        print lines,
    if options.words:
        print words,
    if options.chars:
        print chars,
    print fn
 
def main():
    options, args = opt()
    if not (options.chars or options.words or options.lines):
        options.chars, options.words, options.lines = True, True, True
    if args:
        total_lines, total_words, total_chars = 0, 0, 0
        for fn in args:
            if os.path.isfile(fn):
                with open(fn) as fd:
                    data = fd.read()
                    lines, words, chars = get_Count(data)
                    print_wc(options, lines, words, chars, fn)
                    total_lines += lines
                    total_words += words
                    total_chars += chars
            elif os.path.isdir(fn):
                print >> sys.stderr, "%s: is a directory." % fn
            else:
                sys.stderr.write("%s: No such file or directory.\n" % fn)
        if len(args) >1:
            print_wc(options, total_lines, total_words, total_chars, ‘total‘)
 
    else:
        data = sys.stdin.read()
        fn = ""
        lines, words, chars = get_Count(data)
        print_wc(options, lines, words, chars, fn)
 
if __name__ == ‘__main__‘:
    main()


主要利用了optparse 里的OptionParser 模块,自定义选项。在这里,只定义了-l,-c,-w 三种命令,对应wc 命令的-l,-w,-c 三个命令,分别是统计行数,单词数和字符数。通过OptionParser 模块自定义的命令,python 版本的wc 命令也可以达到linux 命令wc 的效果。


optparse用法详解:

    1. 创建OptionParser 对象,如 parser = OptionParser()

    2. 调用parser 对象的add_option() 方法,自定义选项:

    parser.add_option("-c", 

            "--chars",

            dest = "chars",

            action = "store_true",

            default = False,

            help = "only count chars.")

    "-c"和"--chars"相当于短命令和长命令的区别。

   dest 对象存储的值。

   action 当解释到命令时会如何保存。一般有默认的三种情况,"store"、"store_true"、"stor_false":

   当是"store"时,如果命令后还有值时,会将它保存在dest 声明的那个存储变量,例如<your_script> -c  /etc/hosts; 则将"/etc/hosts"保存在chars 里。

   当是"store_true"时,如果解释到-c 命令,则‘chars‘ : True;

   当是"store_false"时,如果解释到-c 命令,则‘chars‘ : False;

     

   default: action参数的默认取值

   help: 相当于帮助信息


   3. 当所有需要自定义的命令都已经准备好了,就可以调用parser.parse_args() 方法,这个方法返回两个值,options 和args 。

   options 是一个字典dict的形式,这个字典的key 都是以上自定义的命令的dest值。例如,在这个例子里自定义了-c,-w,-l 三种命令选项,它们的action 都是"store_True",当输入有某一个命令时,它对应的存储变量的值就是True , 所以当以这种方式  python  opt_wc.py  -c 执行脚本的时候,就会获取到options 的值:[‘chars‘: True, ‘words‘: Flase, ‘lines‘: False].通过这个字典,就可以知道脚本要处理的命令是哪些了。


  parser.parse_args()方法返回的第二个变量是args, 它是一个列表list,保存了命令行里除了-c,-l和--chars,--lines 这种短命令和长命令以外的参数值。例如命令行 python opt_wc.py  -l /etc/hosts /etc/passwd ,那么args = [‘/etc/hosts‘, ‘/etc/passwd‘], 通过parse_args()方法返回的args 就可以知道脚本需要处理的文件。



python 脚本运行效果:


默认统计行数、字符数、单词数:

技术分享


统计两个文件:

技术分享


只统计行数:

技术分享


输出错误处理:

技术分享


本文出自 “dayAndNight” 博客,请务必保留此出处http://hellocjq.blog.51cto.com/11336969/1859979

用python 实现linux 的wc 命令

标签:python   wc   

原文地址:http://hellocjq.blog.51cto.com/11336969/1859979

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!