一周入门Python之day05


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

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


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

**

学习计划

1,学习目标

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

2,学习内容

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

3,学习时间

每天拿出来两个小时

4,学习产出

优快云技术博客 每天一篇

学习日记

day05 Python的基础语法——模块与包、正则模块

什么是模块

在 Python 中,⼀个 .py ⽂件就可以称之为 ⼀个模块(Module )

目的:
  • 便于代码的维护,将代码按功能分组管理。(放入不同文件,用文件封装;和函数相似,代码用函数封装)

  • 现成的代码实现功能,可以直接使用python中内置的模块,或者网络下载的第三方模块。

  • 避免函数名和变量名冲突。不同的模块命名不会冲突,每个模块都有自己的命名空间。

模块分类

模块分为三种:

  • 内置标准模块
    (⼜称标准库)执⾏ help(‘modules’) 查看所有 python ⾃带模块列表
  • 第三⽅开源模块
    可通过 pip install 模块名 联网安装
    其中plotly是我需要安装的模块名。
  • ⾃定义模块

test.py

import my_module
my_module.sayhi("qinyun")
1.模块

# 导入语法1: import 模块名

# import cal
# import db
#
#
# # 关于计算的逻辑
# print("执行模块")
# print(cal.add(1, 5))
# print(cal.mul(2, 5))
# # 关于数据库调用的逻辑
# db.db_connect()
# db.db_close()
# a = 1
# print(cal.a)


# 导入语法2: from 模块名 import 成员变量
import sys

print("sys.path:::",sys.path)

a = 1
from cal import a as cal_a
from cal import *  # 性能低一些

print(add(1, 3))
print(mul(2, 3))
print(a)
print(cal_a)

import json
json.dumps()

import time
print(time.time())

# import requests

'''
导入模块的路径依赖:1. 内建模块  2 sys.path:[当前执行模块的目录,python环境]
'''

2.程序1调用的其他模块——cal
print("cal模块加载")


def add(x, y):
    return x + y


def sub(x, y):
    return x - y


def mul(x, y):
    return x * y


def div(x, y):
    return x / y


a = 100

3.程序1调用的其他模块——db
import settings

print("db 模块")


def db_connect():
    print("数据库连接 用户名:%s  密码:%s" % (settings.db_user, settings.db_pwd))


def db_close():
    print("关闭数据库")

4.程序1调用的其他模块——settings
print("settings 模块")
db_user = "yuan"
db_pwd = "root"
5.正则模块
import re

# 正则表达式:针对字符串做模糊匹配
# s = "hello yuan"
# print(s.find("yuan"))

# s2 = "1,2,34,100,yuan,rain,alvin,45"
# ret = re.findall("[a-z]+", s2)
# print(ret)

#################### 元字符 ####################

# (1) 通配符 .: 默认模式下匹配除了换行符以外的所有符号

# ret = re.findall("y..n", "hello yuan,hello rain,hello yabn")
# ret = re.findall("y..n", "hello yu\nn,hello rain,hello yabn", re.S)
# print(ret)

# (2) 重复: * [0,无穷]   +[1,无穷]   ?[0,1]  {} 指定范围
# 重点:默认贪婪匹配
# 如何取消贪婪匹配

# ret = re.findall("\d", "1,2,3,55,yuan,33")
# ret = re.findall("hi \d{2}", "hi 1,hi 66,hi 188")
# ret = re.findall("hi \d*", "hi 1,hi 66,hi 188")
# ret = re.findall("\d+", "66,188,2,12222,hello")
# ret = re.findall("\d+?", "66,188,2,12222,hello")  # 取消贪婪匹配
# ret = re.findall("hi \d?", "hi 1,hi 66,hi 188,hi ")  #
# ret = re.findall("hi \d{0,1}", "hi 1,hi 66,hi 188,hi ")  #
# ret = re.findall("hi \d{1,}", "hi 1,hi 66,hi 188,hi ")  #
# ret = re.findall("hi \d{0,}", "hi 1,hi 66,hi 188,hi ")  #
# ret = re.findall("hi \d{1,3}?", "hi 1,hi 66,hi 188,hi ")  #
# print(ret)


# (3) ^  $

# ret = re.findall("^good/.{4}/.{4}", "hello/good/food/meat")
# ret = re.findall("^good/.{4}/meat$", "good/aaaa/meat")
# print(ret)

# (4) [] 字符集匹配[]中任意一个符号, 字符集两个特殊符号 - 范围  ^: 取反
# ret = re.findall("yu[ac]n", "yuan yubn yucn yuacn")
# ret = re.findall("yu[a,c]n", "yuan yubn yucn yu,n")
# ret = re.findall("yu[0123456789]n", "yuan yu8n yucn yu2n")
# ret = re.findall("yu[0-9]n", "yuan yu8n yucn yu2n")
# ret = re.findall("[a-z0-9A-Z]+", "yuan,22,alvin,45,rain")
# ret = re.findall("[^0-9]+", "yuan,22,alvin,45,rain")
# print(ret)

# (5) 分组()  |
# 取消优先提取 ?:
# ret = re.findall("https?://www\.[a-zA-Z0-9]+\.(?:com|cn)",
#                  "http://www.baidu.com,https://www.jd.com,http://www.python.cn,")
# print(ret)

# (6) 转义符  \
# 赋予一些普通符号以特殊功能  [0-9]  \d   \w [0-9a-zA-Z]
# 取消一些特殊符号的特殊功能

ret = re.findall("\d+","123a45bcd678")
print(ret)

6.正则模块2
# 经典组合: .*?  或者 .+?

import re

# ret = re.findall("<div class='c1'>.+?</div>",
#                  "<div><div class='c1'>yuan</div></div><div><div class='c1'>rain</div></div>")
# print(ret)


f = open("douban.html","r",encoding="utf8")
data = f.read()
# print(data)

ret = re.findall('<div class="item">.*?<span class="title">(.+?)</span>.*?<span class="rating_num".*?>(.+?)</span>',data,re.S)
print(ret)
<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、付费专栏及课程。

余额充值