一周入门Python之day04

本文探讨了如何利用Python进行文件读写操作,包括字符和字节处理,以及如何进行JSON数据的序列化与反序列化。还介绍了时间模块的实用技巧,如日期时间处理和随机数生成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


活动地址:优快云21天学习挑战赛

学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。各位小伙伴,如果您:
想系统/深入学习某技术知识点…
一个人摸索学习很难坚持,想组团高效学习…
想写博客但无从下手,急需写作干货注入能量…
热爱写作,愿意让自己成为更好的人…


欢迎参与优快云学习挑战赛,成为更好的自己,请参考活动中各位优质专栏博主的免费高质量专栏资源(这部分优质资源是活动限时免费开放喔~),按照自身的学习领域和学习进度学习并记录自己的学习过程。您可以从以下3个方面任选其一着手(不强制),或者按照自己的理解发布专栏学习作品,参考如下:

**

学习计划

1,学习目标

提示:可以添加学习目标
例如: 一周掌握 Python 入门知识

2,学习内容

提示:可以添加要学的内容
例如:
A,掌握 Python 基本语法
B,掌握 Python 列表、字典、元组等集合类型的用法
C,掌握 Python 函数
D,掌握 Python 常用模块
E, 掌握 Python 模块与包
F,掌握 Python 类与对象

3,学习时间

每天拿出来两个小时

4,学习产出

优快云技术博客 每天一篇

学习日记

day04 Python的基础语法——文件操作

1.文件读操作

'''
s = "苑浩"

ret1 = s.encode("utf8") # 编码:将字符串转为字节数据.默认utf8
print(ret1)


s1 = b"hello world"
print(s1,type(s1))  # b'hello world' <class 'bytes'>


ret2 = ret1.decode("utf8")
print(ret2)

'''


# (1)打开文件: f = open(文件路径,mode="r")
f = open("自嘲诗.txt",mode="r")
# f = open("自嘲诗.txt",mode="rb") # 需要encoding参数
# (2)读所有数据: read()
# data = f.read()
# print(data)
# print(data.decode("GBK"))

# (3)读取几个字符
# data = f.read(2) # 本是
# print(data)

# (4)循环读文件
for line in f:
	print(line,end="")
2.文件写操作
# **********************  写字符  **********************
# f = open("自嘲诗2.txt","w",encoding="utf8") #  覆盖写
# f = open("自嘲诗2.txt", "a", encoding="utf8")  # 追加写
# f.write("本是后山人!\n")
# f.writelines(["偶作钱塘可\n", "醉舞经阁半卷书\n", "坐井说天阔\n"])

# **********************  写字节 **********************
# f = open("自嘲诗2.txt","wb") #  覆盖写
# f = open("a.txt", "ab",)  # 追加写
# f.write("本是后山人!\n".encode())
# f.close()

3.文件拷贝
# f_read = open("自嘲诗2.txt", encoding="utf8")
# f_write = open("自嘲诗3.txt", mode="w", encoding="utf8")
#
# for line in f_read:
#     # 方式1
#     # new_line = line.replace("\n", "。\n")
#     # print(new_line, end="")
#
#     # 方式2
#     # print(repr(line.strip()+"。\n"))
#     new_line = line.strip() + "。\n"
#     f_write.write(new_line)

# 爬取图片

f_read2 = open("meinv.jpg", mode="rb")
f_write2 = open("meinv2.jpg", mode="wb")

for line in f_read2:
    f_write2.write(line)


4.JSON序列化
students_dict = {
    "1001": {"name": "yuan", "scores": {"chinese": 90, "math": 80, "english": 100}},
    "1002": {"name": "rain", "scores": {"chinese": 100, "math": 100, "english": 100}},

}

# 纯文本处理数据方式

# f = open("data.txt","w")
# data = str(students_dict)
# f.write(data)
# f.close()


# f = open("data.txt", "r")
# data = f.read()
#
# print(data["1001"]["name"])


################################# json序列化 #######################################
import json

# 序列化: 通过某种方式把数据结构或对象写入到磁盘文件中或通过网络传到其他节点的过程。
# data1 = (True, None, 123, 'yuan')
# ret1 = json.dumps(data1)
# print(ret1, type(ret1))  # [true, null, 123, "yuan"] <class 'str'>
# print(repr(ret1))  # '[true, null, 123, "yuan"]'
#
# data2 = {"name": 'yuan', "age": 22, "isMarried": False}
#
# ret2 = json.dumps(data2)
# print(repr(ret2))  # '{"name": "yuan", "age": 22, "isMarried": false}'
#
# f = open("data.json", "w")
# f.write(ret2)
# f.close()
# 反序列化:把磁盘中对象或者把网络节点中传输的数据恢复为python的数据对象的过程。

# f = open("data.json")
# data = f.read()
# print(data, type(data))

# 反序列化

data_dict = json.loads('{"name": "yuan", "age": 22, "isMarried": false}')
print(data_dict, type(data_dict))
print(data_dict.get("name"))

# 补充

data_str = '{"name":"yuan","is_married":false,"scores":[100,43,67]}'
js_data = json.loads(data_str)
print(js_data, type(js_data))

res = {"state": True, "err": None}
res_json = json.dumps(res)
print(repr(res_json))
5.时间模块
import time

# time.sleep(10)
'''
"2012-12-12 13:23:15"
"2012-12-12 22:22:20"

"1970-1-1 0:0:0"    0
"1970-1-1 0:0:1"    1
"1970-1-1 1:0:0"    3600
"1970-1-2 0:0:0"    3600*24
"1970-1-3 0:0:0"    3600*24*2
'''
# c1 = time.time()  # 当前时间戳
# print(c1)
# print("hello world")
# time.sleep(3)
# c2 = time.time()  # 当前时间戳
# print(c2)
# print(c2 - c1)

import datetime

'''
四类: date  time   datetime   timedelta 

'''
# 构建一个日期对象
dt = datetime.date(2012, 12, 12)
print(dt.year)
print(dt.month)
print(dt.day)
print(dt)  # 2012-12-12
ret = dt.strftime("%Y/%m/%d")
print(ret)  # 格式化字符串
# 构建当前日期对象
td = datetime.date.today()
print(td)  # 2022-01-15

# datetime类
# 构建日期对象
dt = datetime.datetime(2012, 11, 10, 9, 8, 7)
print(dt.year)
print(dt.month)
print(dt.day)
print(dt.hour)
print(dt)  # 2012-11-10 09:08:07
# ret1 = dt.strftime("%Y/%m/%d %H-%M-%S")
ret1 = dt.strftime("%Y/%m/%d %X")
print(ret1)  # 2012/11/10 09:08:07
# 构建当前日期对象
now = datetime.datetime.now()
print(now)
# 关于日期比较
print(now > dt)

# timedelta
td = datetime.timedelta(days=3)
print(type(td))
print(now - td)
print((now+td).weekday()+1)

# 通过按着格式“1998年12月10日 星期五 13时45分”显示当前时刻三天后的时间

6.随机数模块
import random

print(random.random())  # 0-1随机浮点数
print(random.randint(1, 3))  # 范围整型
print(random.randint(0, 9))  #
print(random.randrange(1, 3))  # 范围整型
print(random.choice(["a", "b", "c"]))  # 多个元素选一个
print(random.sample(["a", "b", "c"], 2))  # 多个元素选多个

l = [1, 2, 3, 4, 5, 6]
random.shuffle(l)
print(l)

# 构建5位验证码
print(ord("a"))
print(ord("b"))
print(ord("z"))
print(chr(97))  # a
print(chr(122))  # z


def get_random_str():
    ret = []
    for i in range(5):
        random_num = str(random.randint(0, 9))
        random_lower = chr(random.randint(97, 122))
        random_upper = chr(random.randint(65, 90))
        random_char = random.choice([random_num, random_upper, random_lower])
        ret.append(random_char)

    print(ret)
    print("".join(ret))

    return "".join(ret)

7.sys模块
import sys

# print(sys.platform)
# if sys.platform == "win32":
#     pass

# sys.exit() # 强制程序退出


# sys.path : 导入包的路径列表


# sys.argv
# print("请登录")
# name = input("用户名:")
# pwd = input("密码:")
#
# if name == "yuan" and pwd == "123":
#     print("登录成功")

# print("sys.argv:", sys.argv)
# user_index = sys.argv.index("-u") + 1
# user = sys.argv[user_index]
# pwd_index = sys.argv.index("-p") + 1
# pwd = sys.argv[pwd_index]
# if user == "yuan" and pwd == "123":
#     print("登录成功")

print(chr)

8.os模块
import os

# print(os.getcwd())  # E:\s32\day04
# os.chdir("E:\s32\day03")
# print(os.getcwd())
# print(os.listdir())

# print(os.path.abspath(os.pardir))

# os.makedirs("wk01/代码",exist_ok=True)
# os.remove("a.txt")

# os.rename("meinv.jpg", "meinv3.jpg")

# data = os.stat("data.txt")
# print(data)
# print(data.st_size)
# print(os.sep)


print(__file__)
print(os.path.abspath(__file__))
print(os.path.abspath("data.json"))
a = os.path.abspath(__file__)
ret = os.path.split(a)
print(ret)  # ('E:\\s32\\day04', '09 os模块.py')
print(os.path.basename(a))
print(os.path.dirname(os.path.dirname(a)))


a = os.path.abspath(__file__)
path = os.path.join(os.path.dirname(a),"new","data.txt")
print("path:",path)
with open(path) as f:
    print(f.read())

print(os.path.getsize(path))

使用vscode作为python编码的ide中遇到的几个问题:

1.运行代码的时候总是默认打开Windows系统自带的cmd或者powershell窗口,而不是下面vscode自带的运行窗口

在这里插入图片描述

解决方法:

1.打开左下角的设置图标;
2.输入Run In Terminal,取消勾选第一个选项;

在这里插入图片描述

2.控制台输出中文乱码:

在这里插入图片描述

解决方法:

1. ctrl + shift + P 打开settings.json
2. 在python运行命令加入编码参数:

在这里插入图片描述

<think>好的,我现在要处理用户关于“蓝桥杯Python一周速成”的查询。首先,我需要理解用户的需求。用户可能是在短时间内需要准备蓝桥杯Python组的比赛,时间紧迫,所以希望得到高效的学习策略和重点内容。 接下来,我应该考虑蓝桥杯Python组的考察范围。通常这类比赛会涉及基础语法、算法、数据结构,以及实际问题的解决能力。由于时间只有一周,用户不可能深入所有细节,因此需要筛选出高频考点和容易快速掌握的内容。 然后,我得规划出一周的学习计划。每天安排不同的主题,比如第一天基础语法,第二天数据结构,第三天算法入门,第四天真题训练,第五天模拟题,第六天查漏补缺,第七天复习调整。每个主题需要突出重点,例如基础语法中的循环、条件判断、函数;数据结构中的列表、字典、字符串处理;算法部分如排序、递归、动态规划基础。 还要考虑用户可能的基础情况。如果用户已经有一定Python基础,重点应放在算法和真题训练上;如果是零基础,可能需要更紧凑的安排,但一周时间确实紧张。不过用户提到“速成”,所以假设有一定的基础,但需要系统复习和强化。 然后,需要给出具体的学习建议。例如推荐哪些资源,官方题库的重要性,时间分配策略,以及调试能力的培养。同时提醒用户避免的误区,比如不要死记硬背代码,或者忽视真题。 可能遇到的问题是如何在短时间内高效掌握关键算法。这时候需要推荐常见的算法题型,如排序、查找、简单动态规划,并提供典型例题,比如斐波那契数列、背包问题等。但要注意复杂度,避免过于复杂的内容。 最后,总结部分需要鼓励用户,强调合理规划和专注的重要性,同时提醒调整心态,保持良好状态参赛。可能还需要提醒用户注意比赛规则和环境,比如蓝桥杯使用的评测系统,编程环境的熟悉等。 检查是否有遗漏点,比如是否需要提到具体的参考资料或在线资源?用户可能希望得到推荐的练习平台,比如蓝桥杯官网、LeetCode简单题、牛客网等。是否需要包含这些信息?根据用户的问题,可能不需要太具体的推荐,但给出一般性建议是合适的。 另外,确保回答结构清晰,分点明确,符合用户可见层的指令要求。使用中文,避免专业术语过于晦涩,同时保持逻辑连贯,帮助用户一步步解决问题。 现在需要将这些思考整理成一个结构化的回答,涵盖每日计划、重点内容、学习建议、注意事项等,确保用户能在一周内高效备考。</think>以下是针对蓝桥杯Python组**一周速成计划**的详细指南,结合高频考点和短期突破策略: --- ### **一、核心考点与优先级** 蓝桥杯Python组侧重**算法实现能力**和**实际问题建模**,重点掌握以下内容(按优先级排序): 1. **基础语法**:输入输出(`input()`格式化处理)、列表推导式、字符串操作(切片、`split()`/`join()`) 2. **数据结构**:列表(排序、二维数组操作)、字典(计数、映射)、集合(去重) 3. **算法**: - **必考**:贪心算法(找零、活动选择)、DFS/BFS基础(迷宫问题)、动态规划(一维DP,如爬楼梯) - **高频**:排序(冒泡、快速排序)、递归(阶乘、斐波那契)、数学问题(质数判断、进制转换) 4. **真题题型**:日期计算、字符串处理、图论基础(最短路径简化版) --- ### **二、7天速成计划表** #### **Day 1-2:语法与数据结构突击** - **上午**: - 输入输出:处理多行输入(如`sys.stdin.read()`),格式化输出(`f-string`对齐) - 列表操作:合并`extend()`、排序`sorted(key=lambda)`、二维列表遍历(矩阵转置) - **下午**: - 字典应用:统计词频(`collections.defaultdict`)、键值反转 - 字符串技巧:`replace()`链式处理、正则表达式简单匹配(如`re.findall(r'\d+',s)`) #### **Day 3-4:算法入门与模板记忆** - **贪心算法**: - 典型题:硬币找零(优先大面值)、区间调度(按结束时间排序) - **DFS/BFS**: - 模板代码:迷宫路径计数(使用栈/队列)、岛屿问题 - **动态规划**: - 一维DP:背包问题(01背包简化版)、最长递增子序列(`O(n^2)`解法) #### **Day 5-6:真题实战与调试技巧** - **刷题策略**: - 近3年初赛真题(官网/题库),限时90分钟模拟 - 重点题型:日期类(闰年判断、星期计算)、数学逻辑(等差数列求和、质因数分解) - **调试技巧**: - 使用`print`定位错误(输出中间变量) - 边界测试:输入为空、极值(如n=0或1e5) #### **Day 7:查漏补缺与策略优化** - **易错点回顾**: - 循环边界错误(如`range(n)` vs `range(1,n+1)`) - 深拷贝/浅拷贝问题(二维列表使用`copy.deepcopy()`) - **时间分配策略**: - 简单题30分钟内AC,难题先写伪代码保部分分 --- ### **三、推荐资源与工具** 1. **练习平台**:蓝桥杯官方练习系统、洛谷(筛选“普及-”难度) 2. **代码模板**:整理DFS/BFS、快速排序等高频算法模板(手写记忆) 3. **效率工具**:使用Python内置函数(如`itertools.permutations`生成排列) --- ### **四、注意事项** - ❌ 避免死磕复杂算法(如线段树、网络流) - ✅ 考试时优先提交**部分正确**的代码(蓝桥杯按用例给分) - ✅ 注意Python特性:大整数运算无需优化,但递归深度默认限制(可设置`sys.setrecursionlimit`) --- 通过**真题驱动学习+模板化训练**,即使时间紧张也能有效提升应试能力。最后一天保持良好作息,调整心态应对比赛!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值