Day 24 - 文件、目录与路径 - Python学习笔记

Udemy - 100 Days of Code: The Complete Python Pro Bootcamp

Day 24 - Intermediate - Files, Directories and Paths

目录

        • [182. Add a High Score to the Snake Game](#182. Add a High Score to the Snake Game)
        • [183. Open, Read and Write Files](#183. Open, Read and Write Files)
        • [184. Read and Write the High Score to a File](#184. Read and Write the High Score to a File)
        • [185. Relative and Absolute File Paths](#185. Relative and Absolute File Paths)
        • [186. Mail Merge Project](#186. Mail Merge Project)
182. Add a High Score to the Snake Game

Snake Game 完整笔记

python 复制代码
class Scoreboard(Turtle):  
    def __init__(self):  
        super().__init__()  
        self.score = 0  
        self.high_score = 0  
        self.color("white")  
        self.hideturtle()  
        self.penup()  
        self.goto(0, 260)  
        self.update_scoreboard()  
    
    def update_scoreboard(self):  
        self.clear()  
        self.write(f"Score: {self.score} High Score: {self.high_score}", align=ALIGNMENT, font=FONT)  
    
    def increase_score(self):  
        self.score += 1  
        self.update_scoreboard()  
    
    def reset(self):  
        if self.score > self.high_score:  
            self.high_score = self.score  
        self.score = 0  
        self.update_scoreboard()


class Snake:
    ...
    def reset(self):  
        for seg in self.segments:  
            seg.goto(1000, 1000)  
        self.segments.clear()  
        self.create_snake()  
        self.head = self.segments[0]


# Detect collision with wall  
if (snake.head.xcor() > 280 or snake.head.xcor() < -280 or  
    snake.head.ycor() > 280 or snake.head.ycor() < -280):  
    scoreboard.reset()  
    snake.reset()  
  
# Detect collision with tail  
for segment in snake.segments[1:]:  
    if snake.head.distance(segment) < 10:  
        scoreboard.reset()  
        snake.reset()
183. Open, Read and Write Files

读写文件

Open

  • open(file, mode='rt', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

参数说明
file:文件路径或文件描述符
mode:打开模式

  • "r" 读取模式(默认),"w" 覆盖模式,"a" 追加模式,"x" 独占创建
  • "t" 文本模式(默认),"b" 二进制模式
  • "+" 可读可写

buffering:缓冲策略

  • 0 无缓冲(仅二进制模式)
  • 1 行缓冲(仅文本模式)
  • >1 指定缓冲区大小(字节)
  • -1 系统默认缓冲策略

encoding:编码格式(仅文本模式)(如 utf-8,gbk,ascii)
errors: 编码报错方式(仅文本模式)(如 "strict" 直接报错, "ignore" 忽略错误字符, "replace" 替换成 �)
newline:换行符设置(仅文本模式)(None,"","\n","\r","\r\n")

closefd:关闭文件时是否同时关闭底层文件描述符
opener:自定义打开器函数

Read

  • 读取文件:read(size=-1)
  • 按行读取:readline(size=-1)
  • 读取行列表:readlines(hint=-1)

Write

  • 写入文件:write(string)
  • 写入行列表:writelines(lines)
python 复制代码
# Read Files
file = open("file.txt")    
print(file.read())    
file.close()  
  
with open("file.txt") as file:  
    print(file.read())  
  
with open("file.txt") as file:  
    print(file.readline())
  
with open("file.txt") as file:  
    print(file.readlines())  
  
with open("file.txt") as file:    
    for line in file:    
        print(line)


# Write Files
with open("file.txt", "a") as file:  
    file.write("append")

with open("file.txt", "w") as file:
    file.write("line 1\nline 2\nline 3\n")

with open("file.txt", "w") as file:
    file.writelines(["line 1\n", "line 2\n", "line 3\n"])


# Create Files
file = open("file.txt", "x") 
file = open("file.txt", "a") 
file = open("file.txt", "w") 
184. Read and Write the High Score to a File

Replit

python 复制代码
class Scoreboard(Turtle):  
    def __init__(self):  
        super().__init__()  
        self.score = 0  
        try:
            with open("data.txt") as file:
                self.high_score = int(file.read())
        except FileNotFoundError:
            self.high_score = 0 
        self.color("white")  
        self.hideturtle()  
        self.penup()  
        self.goto(0, 260)  
        self.update_scoreboard()
    
    def update_scoreboard(self):  
        self.clear()  
        self.write(f"Score: {self.score} High Score: {self.high_score}", align=ALIGNMENT, font=FONT)  
    
    def increase_score(self):  
        self.score += 1  
        self.update_scoreboard()
    
    def reset(self):  
        if self.score > self.high_score:  
            self.high_score = self.score  
            with open("data.txt", "w") as file:  
                file.write(f"{self.high_score}")  
        self.score = 0  
        self.update_scoreboard()
185. Relative and Absolute File Paths
复制代码
Root
└── Work
    ├── app.log
    └── Project
        ├── main.py
        ├── file.txt
        └── assets
            └── img.png

Absolute File Path 绝对文件路径

Root Directory 根目录:/Work/Project/file.txt

Relative File Path 相对文件路径

Parent Directory 上级目录:../app.log

Same Directory 同级目录:./file.txt

Subdirectory 下级目录:assets/img.png

186. Mail Merge Project

Replit

python 复制代码
"""
Dear [name],  
  
You are invited to my birthday this Saturday.  
  
Hope you can make it!  
  
Angela
"""

PLACEHOLDER = "[name]"  

with open("./Input/Names/invited_names.txt") as names_file:  
    names = names_file.readlines()  
  
with open("./Input/Letters/starting_letter.txt") as letter_file:  
    letter_contents = letter_file.read()  
    for name in names:  
        stripped_name = name.strip()  
        new_letter = letter_contents.replace(PLACEHOLDER, stripped_name)  
        with open(f"./Output/ReadyToSend/letter_for_{stripped_name}.txt", "w") as completed_letter:
            completed_letter.write(new_letter)
相关推荐
纵有疾風起4 小时前
C++—string(1):string类的学习与使用
开发语言·c++·经验分享·学习·开源·1024程序员节
yue0085 小时前
C#理论学习-WinForm实践开发教程总结
开发语言·学习·c#
007php0076 小时前
某游戏大厂 Java 面试题深度解析(四)
java·开发语言·python·面试·职场和发展·golang·php
Mr.Jessy6 小时前
Web APIs学习第一天:获取 DOM 对象
开发语言·前端·javascript·学习·html
CodeLongBear6 小时前
Day02计算机网络网络层学习总结:从协议到路由全解析
学习·计算机网络·dubbo
景彡先生7 小时前
Python pandas数据透视表(pivot_table)详解:从入门到实战,多维数据分析利器
python·数据分析·pandas
Blossom.1187 小时前
把AI“编”进草垫:1KB决策树让宠物垫自己报「如厕记录」
java·人工智能·python·算法·决策树·机器学习·宠物
我先去打把游戏先7 小时前
ESP32开发指南(基于IDF):连接AWS,乐鑫官方esp-aws-iot-master例程实验、跑通
开发语言·笔记·单片机·物联网·学习·云计算·aws
oe10198 小时前
好文与笔记分享 A Survey of Context Engineering for Large Language Models(上)
数据库·笔记·语言模型·agent·上下文工程
极客数模8 小时前
2025年(第六届)“大湾区杯”粤港澳金融数学建模竞赛准备!严格遵循要求,拿下大奖!
大数据·python·数学建模·金融·分类·图论·boosting