第6题:工资部门将每个支付周期的雇员信息的列表保存到一个文本文件,

每一行的格式:<last name><hourly wage><hours worked>

编写一个程序,让用户输出文件名并且最终向终端输出报表。

自行创建一个txt文件,如下图所示:

代码:

方法一、从txt文件中读取内容,并向excel表格文件写入

  1. import xlwt
  2. word=[]
  3. fileName=input("请输入文件名:")
  4. f=open(fileName,'r')
  5. content=f.readlines()
  6. i=0
  7. for line in content:
  8. line=line.split()
  9. word.append(line)
  10. f.close()
  11. print(word)
  12. w =xlwt.Workbook(encoding = 'utf-8') #创建一个工作簿
  13. ws =w.add_sheet('1') #创建一个工作表
  14. for i in range(len(content)):
  15. for j in range(len(word[0])):
  16. ws.write(i,j,word[i][j])
  17. w.save('salary.xls')

最终,产生了一个salary.xls文件,文件内的内容和txt中一致

方法二、从txt文件中读取内容,并在控制台以表格形式展现

  1. from prettytable import PrettyTable
  2. word=[]
  3. fileName=input("请输入文件名:")
  4. f=open(fileName,'r')
  5. content=f.readlines()
  6. i=0
  7. for line in content:
  8. line=line.split()
  9. word.append(line)
  10. f.close()
  11. print(word)
  12. for i in range(len(content)):
  13. if i==0:
  14. table = PrettyTable(word[0])
  15. else:
  16. table.add_row(word[i])
  17. table.reversesort = True
  18. print(table)

结果展示:

  1. +----------+-------------+------------+
  2. | lastName | hoursWorked | hourlyWage |
  3. +----------+-------------+------------+
  4. | Bob | 4 | 80 |
  5. | Ann | 8 | 160 |
  6. | Jack | 6 | 120 |
  7. | Lee | 13 | 260 |
  8. | Steven | 24 | 480 |
  9. +----------+-------------+------------+

第7题:在名为stats.py的模块中定义一些函数:计算列数字的中位数、众数和平均数,以列表为参数,返回一个单个的数字

代码:

  1. #以下函数定义在一个stats.py的文件中,
  2. #当import stats,可调用以下函数
  3. #计算中位数
  4. def median(lst):
  5. if len(lst)%2==0:
  6. return lst[len(lst)//2-1:len(lst)//2+1]
  7. else:
  8. return lst[len(lst)//2:len(lst)//2+1]
  9. #计算众数
  10. def mode(lst):
  11. return max(lst.count(x) for x in set(lst))
  12. #计算平均数
  13. def mean(lst):
  14. return sum(lst)/len(lst)

调用自定义模块的步骤(lst是一个列表):

1. 导入该模块:import stats

2.调用函数:stats.median(lst)  or  stats.mode(lst)  or stats.mean(lst)

第8题:编写程序,允许用户在文件的文本中导航。程序提示输入一个文件名,并且输出想要放入到列表中的文本 行, 实际行号范围是从1到文件行数,如果用户输入0,程序退出。否则程序输出和该行号相关的行。

代码:

  1. fileName=input("请输入文件名:")
  2. addLines=input("请输入文本:")
  3. f=open(fileName,'a+')
  4. f.write('\n'+addLines)
  5. f.seek(0)
  6. content=f.readlines()
  7. print(content)
  8. f.close()
  9. num=1
  10. while num:
  11. print("目前文件的行号范围为1~",len(content))
  12. num=int(input("请输入一个行号:"))
  13. if num==0:
  14. break
  15. else:
  16. print(content[num-1])
  17. num=0

结果实例:

第9、10题:写一个简单的图书馆的软件系统,看我的下一个博客,提供转换门:https://blog.csdn.net/LZH_12345/article/details/79679433

Kenneth A.Lambert著的数据结构(用python语言描述)的第一章课后编程答案的更多相关文章

  1. 【数据结构与算法分析——C语言描述】第一章总结 引论

    这一章主要复习了一些数学知识,像指数.对数.模运算.级数公式:还有2种证明方法,归纳假设法和反证法.所幸以前学过,重新拾捡起来也比较轻松. 简要地复习了递归,提出了编写递归例程的四条基本法则: 基准情 ...

  2. 读书笔记《数据结构与算法JavaScript描述》第一章

    第一章JavaScript的编程环境和模型 1.2JavaScript编程实践 1.2.1 声明和初始化变量 JavaScript中的变量默认为全局变量,如果初始化未被声明的变量,该变量就成了一个全局 ...

  3. 数据结构与算法分析——C语言描述 第三章的单链表

    数据结构与算法分析--C语言描述 第三章的单链表 很基础的东西.走一遍流程.有人说学编程最简单最笨的方法就是把书上的代码敲一遍.这个我是头文件是照抄的..c源文件自己实现. list.h typede ...

  4. 列表的实现-----数据结构与算法JavaScript描述 第三章

    实现一个列表 script var booklist = new List(); booklist.append('jsbook'); booklist.append('cssbook'); book ...

  5. 数据结构(python语言)目录链接

    第一章 准备工作 课时0:0.数据结构(python语言) 基本概念 算法的代价及度量!!!

  6. Python之旅_第一章Python入门

    一.编程语言分类 1.机器语言:即计算机能听懂的二进制语言,0000 0001,直接操控硬件: 2.汇编语言:简写的英文标识符代替二进制语言,本质同样是直接操控硬件: 3.高级语言:用更贴近人类的语言 ...

  7. 数据结构(java语言描述)

    概念性描述与<数据结构实例教程>大同小异,具体参考:http://www.cnblogs.com/bookwed/p/6763300.html. 概述 基本概念及术语 数据 信息的载体,是 ...

  8. 《数据结构与算法Python语言描述》习题第二章第三题(python版)

    ADT Rational: #定义有理数的抽象数据类型 Rational(self, int num, int den) #构造有理数num/den +(self, Rational r2) #求出本 ...

  9. 《数据结构与算法Python语言描述》习题第二章第二题(python版)

    ADT Date: #定义日期对象的抽象数据类型 Date(self, int year, int month, int day) #构造表示year/month/day的对象 difference( ...

随机推荐

  1. 编译最新linux内核(version 4.4.2)

    环境:centos6.4 内核版本为2.6.32 目标:编译4.4.2内核,升级到 4.4.2 准备工作: 安装开发库和ncurses库 # yum groupinstall "Develo ...

  2. 笔记-JavaWeb学习之旅17

    1.过滤选择器 首元素选择器:first 获得选择的元素中的第一个元素 尾元素选择器:last获得选择元素中的最后一个元素 非元素选择器:not(selector) 不包括指定内容的元素 偶数选择器: ...

  3. VMware workstation 14 安装 iOS虚拟机

    https://03k.org/vmware-macos.html https://jingyan.baidu.com/article/363872ec206a356e4ba16f30.html 1. ...

  4. Mac客户端CentOS服务器 SSH免密码登陆

    假定有2个服务器A(127.0.0.1)和B(192.168.0.1),A作为客户端来登录服务器B 1.在服务器A下使用 ssh-keygen -t ras -P 会在-/.ssh目录下'生成公钥(i ...

  5. 【手撸一个ORM】第九步、orm默认配置类 MyDbConfiguration,一次配置,简化实例化流程

    这个实现比较简单,事实上可配置的项目很多,如有需要,请读者自行扩展 using System; namespace MyOrm { public class MyDbConfiguration { p ...

  6. 第十七章 提升用户体验 之 使用MVC扩展功能控制程序行为

    1. 概述 ASP.NET MVC具有很好的扩展性,每一个核心功能都可以被扩展.重写 和 定制. 本章内容包括:实现MVC过滤器和controller工厂.使用 action results,view ...

  7. 记录下这周的mysql调优工作

    这周一至周四基本都在做mysql的测试和调优工作,包括erlang端对mysql的写入测试,到今天为止暂且告一段落,下周先做下其他的开发.    测试环境    使用的测试环境是aliyun的杭州节点 ...

  8. AtCoderBeginnerContest109题解

    第一次AK,真爽qwq A 很zz啊,,直接判断三种情况就行 /* */ #include<iostream> #include<cstdio> #include<cst ...

  9. 【虚拟机-虚拟网络】使用 PsPing & PaPing 进行 TCP 端口连通性测试

    PsPing & PaPing 介绍 通常,我们测试数据包能否通过 IP 协议到达特定主机时,都习惯使用 ping 命令.工作时 ping 向目标主机发送一个 IMCP Echo 请求的数据包 ...

  10. Windows 7, Visual Studio 2015下编译Webkit

    因工作需要,需要编译Windows版本的Webkit,中间走了不少弯路,都记录下来,供大家参考!也随时欢迎大家讨论(QQ群:345802342) 整个编译工作参考的是官方文档:https://webk ...