鱼c工作室python-鱼C工作室Python作业

1,使用getopt。getopt()优化当前的功能函数:

[html]

#!/usr/bin/python

# -*- coding: utf-8 -*-

#coding=utf-8

import os,sys

import getopt

print sys.argv

CDROW='/home/zhouqian/test'

def cdWalker(CDROW,cdfile):

result=[]

for root,dirs,files in os.walk(CDROW):

result.append("%s %s %s" %(root,dirs,files))

print root

open(cdfile,'w').write(' '.join(result))

def usage():

print '''pycdc 使用方式:

python cdays-3-exercise-1.py -d cdc -k 中国火

#检索cdc中有没有中国火字样的目录,

'''

try:

opts,args=getopt.getopt(sys.argv[1:],'hd:e:k:')

except getopt.GetoptError:

usage()

sys.exit()

if len(opts)==0:

usage()

sys.exit()

c_path=''

name=''

for opt,arg in opts:

if opt in('-h','--help'):

usage()

sys.exit()

elif opt=='-e':

if os.path.exists(arg):#判断目标路径是否存在

# cdWalker(CDROW,arg)

print "记录光盘的位置是 %s" %arg

else:

print "不存在这样的目录"

elif opt=='-d':

c_path=arg

print c_path

cdWalker(CDROW,c_path)

elif opt=='-k':

if not c_path:

usage()

sys.exit()

else:

name=arg

for root,dirs,files in os.walk(c_path):

if root=='%s' %name:

print '您要找的文件在%s' %dirs

这是第一个题,大概做了2个小时吧,各种纠结啊,后面两个正在做。中间遇到的问题总结:

函式的利用,os.path.walk,python字符集,getopt模块的使用学习,os.path.exists()的利用,列表的对应关系等等

习题2 :关键词-----》序列号问题:

[html]

#!/usr/bin/python

#coding=utf-8

import sys

def collect(file):

result={}

for line in file.readlines():

left,right=line.split()

if result.has_key(right):

result[right].append(left)

else:

result[right]=[left]

return result

if __name__=="__main__":

print sys.argv

if len(sys.argv)==1:

print 'usage: python value_keys.py test.txt'

else:

result=collect(open(sys.argv[1],'r'))

for (right,left) in result.items():

print "%d %s => %s" %(len(left),right,left)

结果显示:

[html]

root@zhou:/home/zhouqian/python# py value_keys.py test.txt

ssss

2 key3 => ['6', '33']

3 key2 => ['1', '2', '45']

3 key1 => ['4', '5', '13']

遇到的问题总结:

split的用法:line.split()就是分开出左右两边的值,在默认的情况下是以一个空格或者多个空格为分割符的,

has_key()的用法:是查看字典数据类型中有没有这么一个关键字。上面可知result={}是初始化了一个字典的数据类型。

字典的一些用法:怎么定义,怎么赋值:result[right]=[left]或者result[right]=left,遍历字典中所用

项,result.items(),遍历字典的key值:result.keys(),遍历字典的value值:result.values()

[html]

>>> dict={'chen':25,'zhou':24,'xiao':35}

>>> dict.values()

[25, 35, 24]

>>> dict.keys()

['chen', 'xiao', 'zhou']

>>> dict.items()

[('chen', 25), ('xiao', 35), ('zhou', 24)]

追问 : 非常感谢您啊,能麻烦您给网页截个图吗?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值