[python]《Python编程快速上手:让繁琐工作自动化》学习笔记2
1. 读写文件笔记(第8章)(代码下载)
1.1 文件与文件路径
通过import os调用os模块操作目录,常用函数如下:
| 函数 | 用途 |
|---|---|
| os.getcwd() | 取得当前工作路径 |
| os.chdir() | 改变当前工作路径 |
| os.makedirs(path) | 创建新文件夹 |
| os.listdir(path) | 返回文件名字符串的列表 |
| os.path.join(path1,path2,...) | 连接路径 |
| os.path.abspath(path) | 返回绝对路径 |
| os.path.isabs(path) | 检查是否绝对路径 |
| os.path.relpath(path, start) | 返回从start路径到path的相对路径 |
| os.path.dirname(path) | 返回目录名 |
| os.path.basename(path) | 返回文件名 |
| os.path.split(path) | 返回目录名和文件名的元组 |
| os.path.getsize(path) | 返回path参数中文件的字节数 |
| os.path.exists(path) | 检查路径是否存在 |
| os.path.isfile(path) | 检查路径是否文件 |
| os.path.isdir(path) | 检查路径是否文件夹 |
1.2 文件读写
在Python 中,读写文件有3 个步骤:
- 调用open()函数,返回一个File 对象。
- 调用File 对象的read()或write()方法。
- 调用File 对象的close()方法,关闭该文件
# 将'w'作为第二个参数传递给open(),以写模式打开该文件
# 写模式会清空源文件
baconFile = open('bacon.txt', 'w')
baconFile.write('Hello world!\n')
baconFile.close()
# 将'a'作为第二个参数传递给open(),以添加模式打开该文件
# 添加模式将在已有文件的末尾添加文本
baconFile = open('bacon.txt', 'a')
baconFile.write('Bacon is not a vegetable.')
baconFile.close()
# 读文件
baconFile = open('bacon.txt')
# read将文件的内容看成是单个大字符串
content = baconFile.read()
# readlines从该文件取得一个字符串的列表。列表中的每个字符串就是文本中的每一行
# content = baconFile.readlines()
baconFile.close()
print(content)
Hello world!
Bacon is not a vegetable.
2. 项目练习
2.1 生成随机的测验试卷文件
# -*- coding: utf-8 -*-
import random
# 测验数据
# The quiz data. Keys are states and values are their capitals.
capitals = {'Alabama': 'Montgomery', 'Alaska': 'Juneau', 'Arizona': 'Phoenix',
'Arkansas': 'Little Rock', 'California': 'Sacramento', 'Colorado': 'Denver',
'Connecticut': 'Hartford', 'Delaware': 'Dover', 'Florida': 'Tallahassee',
'Georgia': 'Atlanta', 'Hawaii': 'Honolulu', 'Idaho': 'Boise', 'Illinois':
'Springfield', 'Indiana': 'Indianapolis', 'Iowa': 'Des Moines', 'Kansas':
'Topeka', 'Kentucky': 'Frankfort', 'Louisiana': 'Baton Rouge', 'Maine':
'Augusta', 'Maryland': 'Annapolis', 'Massachusetts': 'Boston', 'Michigan':
'Lansing', 'Minnesota': 'Saint Paul', 'Mississippi': 'Jackson', 'Missouri':
'Jefferson City', 'Montana': 'Helena', 'Nebraska': 'Lincoln', 'Nevada':
'Carson City', 'New Hampshire': 'Concord', 'New Jersey': 'Trenton', 'New Mexico': 'Santa Fe', 'New York': 'Albany', 'North Carolina': 'Raleigh',
'North Dakota': 'Bismarck', 'Ohio': 'Columbus', 'Oklahoma': 'Oklahoma City',
'Oregon': 'Salem', 'Pennsylvania': 'Harrisburg', 'Rhode Island': 'Providence',
'South Carolina': 'Columbia', 'South Dakota': 'Pierre', 'Tennessee':
'Nashville', 'Texas': 'Austin', 'Utah': 'Salt Lake City', 'Vermont':
'Montpelier', 'Virginia': 'Richmond', 'Washington': 'Olympia',
'West Virginia': 'Charleston', 'Wisconsin': 'Madison', 'Wyoming': 'Cheyenne'}
# 生成试卷
# 试卷份数
n_quiz=2
for quizNum in range(n_quiz):
# Create the quiz and answer key files.
# 试卷
quizFile = open('capitalsquiz%s.txt' % (quizNum + 1), 'w')
# 答案
answerKeyFile = open('capitalsquiz_answers%s.txt' % (quizNum + 1), 'w')
# Write out the header for the quiz.
# 头文件
quizFile.write('Name:\n\nDate:\n\nPeriod:\n\n')
quizFile.write((' ' * 20) + 'State Capitals Quiz (Form %s)' % (quizNum + 1))
quizFile.write('\n\n')
# Shuffle the order of the states.
states = list(capitals.keys())
# 创建了美国州名的随机列表
random.shuffle(states)
# 创建答案
# Loop through all 50 states, making a question for each.
for questionNum in range(50):
# Get right and wrong answers.
# 正确答案
correctAnswer = capitals[states[questionNum]]
# 错误答案
wrongAnswers = list(capitals.values())
# 删除正确的答案
del wrongAnswers[wrongAnswers.index(correctAnswer)]
# 随机取出三个答案
wrongAnswers = random.sample(wrongAnswers, 3)
answerOptions = wrongAnswers + [correctAnswer]
random.shuffle(answerOptions)
# 将内容写入测验试卷和答案文件
# Write the question and the answer options to the quiz file.
quizFile.write('%s. What is the capital of %s?\n' % (questionNum + 1,states[questionNum]))
for i in range(4):
quizFile.write(' %s. %s\n' % ('ABCD'[i], answerOptions[i]))
quizFile.write('\n')
# Write the answer key to a file.
answerKeyFile.write('%s. %s\n' % (questionNum + 1, 'ABCD'[answerOptions.index(correctAnswer)]))
quizFile.close()
answerKeyFile.close()
2.2 疯狂填词
创建一个疯狂填词(Mad Libs)程序,它将读入文本文件,并让用户在该文本文件中出现ADJECTIVE、NOUN、ADVERB 或VERB 等单词的地方,加上他们自己的文本。
import re
# text:
'''
The ADJECTIVE panda walked to the NOUN and then VERB. A nearby NOUN was unaffected by these events
'''
# 输入文件
input_file = open('./input_text.txt')
input_text = input_file.read()
input_file.close()
# 输出文本
output_text = input_text
# 输入文本寻找关键词
keywords = re.compile('adjective|noun|verb', re.IGNORECASE)
mo = keywords.findall(input_text)
# 一个一个词进行替换
for word in mo:
if word[0].lower() == 'a':
replacewords = input('Enter an {}:\n'.format(word))
else:
replacewords = input('Enter a {}:\n'.format(word))
regex = re.compile(word)
# 每一次替换一个词
output_text = regex.sub(replacewords, output_text, 1)
# 写入新文件
output_file = open('output_text.txt', 'w')
output_file.write(output_text)
output_file.close()
print(output_text)
Enter an ADJECTIVE:
silly
Enter a NOUN:
chandelier
Enter a VERB:
screamed
Enter a NOUN:
pickup truck
The silly panda walked to the chandelier and then screamed. A nearby pickup truck was unaffected by these events.
2.3 正则表达式查找
编写一个程序,打开文件夹中所有的.txt 文件,查找匹配用户提供的正则表达式的所有行。结果应该打印到屏幕上。
import os
import re
path = "./"
# 判断路径目录是否存在
folder = os.path.exists(path)
if folder == False:
print("文件目录不存在!")
#返回指定目录下所有的文件名和文件夹名列表
file_Name = os.listdir(path)
#创建正则表达式
keywords = re.compile(r'ADJECTIVE')
# 找出txt文件
for i in range(len(file_Name)):
#判断是否为txt文件
if os.path.isfile(os.path.join(path, file_Name[i])) and file_Name[i].split('.')[-1] == 'txt':
# 打开文件
file = open(os.path.join(path, file_Name[i]))
file_texts = file.readlines()
for texts in file_texts:
#找出匹配正则表达式的内容
text_put = keywords.search(texts)
#输出结果
if text_put != None:
#打印当前行
print('{}'.format(texts))
The ADJECTIVE panda walked to the NOUN and then VERB. A nearby NOUN was unaffected by these events.
[python]《Python编程快速上手:让繁琐工作自动化》学习笔记2的更多相关文章
- python学习笔记整理——字典
python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...
- VS2013中Python学习笔记[Django Web的第一个网页]
前言 前面我简单介绍了Python的Hello World.看到有人问我搞搞Python的Web,一时兴起,就来试试看. 第一篇 VS2013中Python学习笔记[环境搭建] 简单介绍Python环 ...
- python学习笔记之module && package
个人总结: import module,module就是文件名,导入那个python文件 import package,package就是一个文件夹,导入的文件夹下有一个__init__.py的文件, ...
- python学习笔记(六)文件夹遍历,异常处理
python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...
- python学习笔记--Django入门四 管理站点--二
接上一节 python学习笔记--Django入门四 管理站点 设置字段可选 编辑Book模块在email字段上加上blank=True,指定email字段为可选,代码如下: class Autho ...
- python学习笔记--Django入门0 安装dangjo
经过这几天的折腾,经历了Django的各种报错,翻译的内容虽然不错,但是与实际的版本有差别,会出现各种奇葩的错误.现在终于找到了解决方法:查看英文原版内容:http://djangobook.com/ ...
- python学习笔记(一)元组,序列,字典
python学习笔记(一)元组,序列,字典
- Pythoner | 你像从前一样的Python学习笔记
Pythoner | 你像从前一样的Python学习笔记 Pythoner
- OpenCV之Python学习笔记
OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书< ...
- python学习笔记(五岁以下儿童)深深浅浅的副本复印件,文件和文件夹
python学习笔记(五岁以下儿童) 深拷贝-浅拷贝 浅拷贝就是对引用的拷贝(仅仅拷贝父对象) 深拷贝就是对对象的资源拷贝 普通的复制,仅仅是添加了一个指向同一个地址空间的"标签" ...
随机推荐
- CentOS 7 安全基线检查
注意:操作时建议做好记录或备份 1.设置密码失效时间 | 身份鉴别 描述: 设置密码失效时间,强制定期修改密码,减少密码被泄漏和猜测风险,使用非密码登陆方式(如密钥对)请忽略此项. 加固建议: 使用非 ...
- PHP获取两个时间差
<?php //PHP计算两个时间差的方法 $startdate="2017-12-3 12:00:00"; $enddate="2017-12-4 12:00:0 ...
- 1NF | 2NF | 3NF的区分以及什么是函数依赖、部分函数依赖、值传递依赖(最详细的讲解1NF、2NF、3NF的关系)
1NF | 2NF | 3NF的区分以及什么是函数依赖.部分函数依赖.值传递依赖 符合3NF一定符合2NF.一定符合1IF 简单区分.2NF不存在部分函数依赖,3NF不存在传递函数依赖 第一范式1NF ...
- vue3+element-plus+登录逻辑token+环境搭建
vue3+element-plus+登录逻辑token环境搭建 安装脚手架工具 1 npm i @vue/cli@4.5.13 -g 验证是否安装成功 1 vue -V # 输出 @vue/cli 4 ...
- CH58X服务修改
在对ble系列应用时,很多时候拿手机充当主机.在使用ble 调试助手时常会用到write.read.notify等功能.有时可能会根据自己的需求对这些服务进行修改.下图是官方例程体现出的service ...
- Element基本组件
Element按钮组件: <el-row> <el-button>默认按钮</el-button> <el-button type="primary ...
- 数组还是HashSet?
我记得大约在半年前,有个朋友问我一个问题,现在有一个选型: 一个性能敏感场景,有一个集合,需要确定某一个元素在不在这个集合中,我是用数组直接Contains还是使用HashSet<T>.C ...
- Go语言核心36讲17
在前面的文章中,我们已经提到过很多次"指针"了,你应该已经比较熟悉了.不过,我们那时大多指的是指针类型及其对应的指针值,今天我们讲的则是更为深入的内容. 让我们先来复习一下. ty ...
- kubeedge架构与核心设计---https://bbs.huaweicloud.com/webinar/100009
今天是kubeedge的第一节课,今天主要带大家回顾一下云原生和边缘计算的发展历程 然后我们会重点介绍一下kubeedge这个项目,他的设计背景和核心理念与我们整体的架构 首先是我们来简单回归一下云原 ...
- (工具) 交叉编译 gperftools及使用
交叉编译gperftools及使用 sudo apt-get install kcachegrind # 导出为 callgrind 格式时需要 sudo apt install doxygen-la ...