python核心编程第9章习题:9-7

解析文件. Win32 用户: 创建一个用来解析 Windows .ini 文件的程序. POSIX 用户:创建一个解析 /etc/serves 文件的程序. 其它平台用户: 写一个解析特定结构的系统配置文件的程序.

网上的例子多是解析 windows 的win.ini 的,这个相对简单些。

这里是解析/etc/services的,由于某些列(各列可以看做配置项)可能为空,需要对怎么取出各列和判断可能为空的列做些处理。

用dict存储解析结果:

dict的每个key的名字就是该行的第一列(服务名),这个key的value就是该行其他元素组成的list,且list的每个元素以 配置项名称  =  配置项值 的形式出现。

# coding:utf-8

import re

# 把文件读取进来, 每行存放到list, 不断增加list元素, 注释行忽略

def file_analyze(fname):
    line_list = list()
    with open(fname, ‘r‘) as fd:
        for eachline in fd:
            if eachline.startswith(‘#‘):
                continue
            line_list.append(eachline)
    return line_list

# 用一个dict存放解析结果, dict的每个元素是一个list, dict的每个key-value对是每行的解析结果
# 怎么区分每列呢?第一二列区分方法用空格
# 第四列用#分割出来就行
# 第三四列的区分方法是把每行去掉第四列后, 再去掉第一列和第二列
# 其中需要对第三列和第四列可能为空的情况做判断

# item就是文件的每行

def column_analyze(file_list):
    for item in file_list:
        line_analyze_list = list()
        service_name, tmp_port_protocol, port_protocol, aliases, comment =             str(), str(), str(), str(), str()
        if len(item.strip(‘\n‘).strip(‘\s‘)) == 0:
            continue
        for unit in re.split(‘//s+‘, item):
            service_name = unit.split()[0]
            tmp_port_protocol = unit.split()[1].strip()
            port_protocol = ‘port_protocol = ‘ + unit.split()[1].strip()
            line_analyze_list.append(port_protocol)
            tmp_aliases = unit.split(‘#‘)[0].strip(service_name).lstrip().                strip(tmp_port_protocol)
            if len(tmp_aliases.strip()) == 0:
                aliases = ‘aliases = ‘
            else:
                aliases = ‘aliases = ‘ + unit.split(‘#‘)[0].                    strip(service_name).                    lstrip().strip(tmp_port_protocol).strip()
            line_analyze_list.append(aliases)
            if unit.find(‘#‘) < 0:
                comment = ‘comment = ‘
            else:
                comment = ‘comment = ‘ + unit.split(‘#‘)[1].strip().strip(‘\n‘)
            line_analyze_list.append(comment)
            analyze_dict[service_name] = line_analyze_list
    return analyze_dict

def main(fname, listname):
    listname = file_analyze(fname)
    analyze_dict = column_analyze(listname)

if __name__ == ‘__main__‘:
    analyze_list = list()
    analyze_dict = dict()
    file_name = ‘/etc/services‘
    main(file_name, analyze_list)
    print analyze_dict
时间: 2024-10-06 22:41:38

python核心编程第9章习题:9-7的相关文章

Python核心编程第五章习题

Python核心编程-第五章-习题 5.1  整形,讲讲Python普通整形与长整形的区别? Python的标准整形类型是最通用的数字类型.在大多数32位机器上,标准整形类型的取值范围是-2**32-2**32 - 1. Python的长整型类型能表达的数值仅仅与你的机器支持的(虚拟)内存大小有关,换句话说,Python能轻松表达很大的整数. 长整型类型是标准整形类型的超集,当程序需要使用比标准整形更大的整型时,可以使用长整型类型,在整型值后面添加L,表示这个为长整型,3.0版本已经统一称为为整

python核心编程-第三章-习题

1.这是python的语言特性,python先创建对象,在给变量赋值时,不需要定义变量的名称和类型,它实际是用变量引用对象.变量类型在给变量赋值时自动声明 2.原因类似变量无须声明类型 3.python用下划线作为变量前缀和后缀指定特殊变量,对解释器有特殊意义,也是内建标识符所使用的特殊符号,故一般避免用下划线作为变量的开头和结尾 4.python一行可以书写多个语句,多个语句间用";"分隔.但是为了良好的编程风格,不推荐这么做 5.python可以将一个语句分成多行书写,行的末尾用反

python核心编程-第四章-习题

1.身份.类型.值.其中,身份是每个对象的标识,与内存地址密切相关,可用id()返回:类型决定了对象可以保存什么类型的值,用type()函数.isinstance()函数可以得到对象的类型:值就是对象表示的数据 2.不可更改指对象创建以后值不可以更新.python中,列表.字典是可更改的,数字.字符串.元组是不可更改的 3.类型 字符串.列表.元组是按照顺序访问的,也就是具有切片的特性. 映射类型(字典)类似序列的索引,但它的索引不是按顺序的数字来切片,而是通过一个唯一的键或者说关键字来访问,容

python 核心编程 第六章习题

6-6 创建一个类似 string.strip() 函数 方法一 低效方法 大量复制和生成子串对象 def str_strip(s): while len(s)>=2: if s[0]==' ': s=s[1:] else: break while len(s)>=2: if s[-1]==' ': s=s[:-1] else: break if s==' ' or s=='': return '' else: return s 方法二: 转换成列表 def str_strip(s): if

python 核心编程 第七章习题

7-9. 翻译(a) 编写一个字符翻译程序(功能类似于Unix 中的tr 命令).我们将这个函数叫做tr(),它有三个字符串做参数: 源字符串.目的字符串.基本字符串,语法定义如下:def tr(srcstr, dststr, string)srcstr 的内容是你打算"翻译"的字符集合,dsrstr 是翻译后得到的字符集合,而string 是你打算进行翻译操作的字符串.举例来说,如果srcstr == 'abc', dststr == 'mno', string =='abcdef'

[python核心编程] 第五章练习题

第五章 数字 5-2. 操作符,写一个函数,计算并返回两个数的乘积“整理的时候才看到我把题目看成两个数的和了” 5-3. 标准类型操作符.写一段脚本,输入一个测验成绩,根据下面的标准,输出他的评分成绩(A-F) A:90~100 B:80~89 C:70~79 D:60~69 F:<60 5-4. 取余.判断给定年份是否是闰年.使用下面的公式. 一个闰年后就是指他可以被4整除,但不能被100整除,或者它可以被400整除. [python核心编程] 第五章练习题,布布扣,bubuko.com

python核心编程--第六章 6.22 练习

6.22 练习 初学python,如果代码有问题,欢迎指正. #!/usr/bin/python # -*- coding: utf-8 -*- #6–1. 字符串.string 模块中是否有一种字符串方法或者函数 #可以帮我鉴定一下一个字符串是否是另一个大字符串的一部分? import string ss = "I'm chinese." substr = 'chinese' index = ss.find(substr) if index == -1: print("No

python核心编程--第其章 7.12 练习

7.12 练习 #!/usr/bin/python # -*- coding: utf-8 -*- # 7–5. userpw2.py. 下面的问题和例题7.1 中管理名字-密码的键值对数据的程序有关. # (a) 修改那个脚本,使它能记录用户上次的登录日期和时间(用time 模块), # 并与用户密码一起保存起来.程序的界面有要求用户输入用户名和密码的提示. # 无论户名是否成功登录,都应有提示,在户名成功登录后,应更新相应用户的上次 # 登录时间戳.如果本次登录与上次登录在时间上相差不超过4

Python核心编程_第二章课后习题

以下是自己在学习Python核心编程时,做的课后练习题.现在把它们贴出来,以记录自己的学习过程.小弟是机械出身,很多练习题目写的很是机械.虽然写出来的脚本都能满足题目要求,但效率可能不是最好的,所以,小弟还是厚着脸皮把它们给贴出来,一来可以让高手指点,二来可以与我一样在学习Python的兄弟共同学习. 以下的程序均以题目标号命名,如2-3这个题目,程序名就为2_3.py. 习题2_3.py #!/usr/bin/env python A = 10 B = 4 print "A plus B is