Python小白必做的30道基础练习题(附保姆级答案解析)

这里是为 Python 真正的小白 准备的 30道超基础练习题(2026年视角),难度从输入输出 → 变量 → 条件 → 循环 → 字符串 → 列表 → 函数逐步递增。

每道题都附带:

  • 题目描述
  • 参考答案(最简单、最清晰的写法)
  • 核心知识点 + 小提示(保姆级解析)

建议做法
先自己写 10–15 分钟 → 看不懂再看答案 → 看完答案立刻自己敲一遍 → 改一改输入试试不同情况。

1–10:最基础(输入输出 + 变量 + 运算)

  1. 写一个程序,打印 “Hello, Python小白!2026加油!”
print("Hello, Python小白!2026加油!")
  1. 定义两个变量 a=10,b=3,打印它们的和、差、积、商(保留2位小数)
a =10 b =3print(a + b)# 13print(a - b)# 7print(a * b)# 30print(f"{a / b:.2f}")# 3.33
  1. 从键盘输入两个整数,计算并打印它们的乘积
x =int(input("请输入第一个数:")) y =int(input("请输入第二个数:"))print("乘积是:", x * y)
  1. 输入一个数字,判断它是奇数还是偶数
n =int(input("输入一个整数:"))if n %2==0:print("偶数")else:print("奇数")
  1. 输入身高(米)和体重(公斤),计算 BMI 并判断体型
    (BMI = 体重 / 身高²,<18.5偏瘦,18.5-23.9正常,≥24超重)
height =float(input("身高(米):")) weight =float(input("体重(kg):")) bmi = weight /(height **2)print(f"BMI = {bmi:.2f}")if bmi <18.5:print("偏瘦")elif bmi <=23.9:print("正常")else:print("超重")
  1. 输入年份,判断是否是闰年
    (能被4整除且不能被100整除,或能被400整除)
year =int(input("输入年份:"))if(year %4==0and year %100!=0)or(year %400==0):print("闰年")else:print("平年")
  1. 打印 1 到 10 的所有整数(用while和for两种方式)
# while i =1while i <=10:print(i, end=" ") i +=1print()# 换行# forfor i inrange(1,11):print(i, end=" ")
  1. 计算 1 + 2 + 3 + … + 100 的和(用for和while各写一次)
# for版 s =0for i inrange(1,101): s += i print(s)# 5050# while版 s =0 i =1while i <=100: s += i i +=1print(s)
  1. 打印九九乘法表(完整版)
for i inrange(1,10):for j inrange(1, i+1):print(f"{j}×{i}={i*j:2d}", end=" ")print()
  1. 输入一个正整数 n,打印 n 行星号三角形(第一行1个*,第二行2个…)
n =int(input("输入行数:"))for i inrange(1, n+1):print("*"* i)

11–20:字符串 + 列表基础

  1. 输入一句话,把所有空格替换成下划线 _
s =input("输入一句话:")print(s.replace(" ","_"))
  1. 输入一个字符串,统计其中字母 ‘a’ 出现的次数(不区分大小写)
s =input("输入字符串:").lower()print("a 出现了", s.count('a'),"次")
  1. 输入三个整数,用空格分隔,一行输入,存入列表并排序后输出
nums =list(map(int,input("输入三个整数,用空格隔开:").split())) nums.sort()print(nums)
  1. 有一个列表 names = [“张三”, “李四”, “王五”, “赵六”],在"王五"后面插入"孙七"
names =["张三","李四","王五","赵六"] names.insert(3,"孙七")# 或 names.insert(names.index("王五")+1, "孙七")print(names)
  1. 列表 fruits = [“apple”, “banana”, “cherry”, “apple”],删除所有 “apple”
fruits =["apple","banana","cherry","apple"] fruits =[f for f in fruits if f !="apple"]# 列表推导式最简洁# 或者:while "apple" in fruits: fruits.remove("apple")print(fruits)
  1. 产生一个包含 1–100 所有能被3整除的数的列表
lst =[i for i inrange(1,101)if i %3==0]print(lst)
  1. 输入一个字符串,反转后输出(三种方法任选)
s =input("输入:")# 方法1 最常用print(s[::-1])# 方法2print("".join(reversed(s)))# 方法3print(s[len(s)::-1])# 记住这个也行
  1. 判断一个字符串是否是回文串(正读反读一样,如 “radar”)
s =input("输入字符串:").lower().replace(" ","")# 忽略大小写和空格if s == s[::-1]:print("是回文")else:print("不是回文")
  1. 把字符串 “1,2,3,4,5” 转成列表 [1,2,3,4,5](元素是整数)
s ="1,2,3,4,5" lst =[int(x)for x in s.split(",")]print(lst)
  1. 有一个列表 scores = [89, 76, 65, 92, 58, 77],统计及格(>=60)的人数
scores =[89,76,65,92,58,77] count =sum(1for x in scores if x >=60)# 或 len([x for x in scores if x >= 60])print("及格人数:", count)

21–30:函数 + 综合小练习

  1. 写一个函数,接收两个数,返回较大的那个
defmax2(a, b):return a if a > b else b print(max2(10,25))# 25
  1. 写一个函数 is_prime(n),判断 n 是否是素数
defis_prime(n):if n <2:returnFalsefor i inrange(2,int(n**0.5)+1):if n % i ==0:returnFalsereturnTrueprint(is_prime(17))# Trueprint(is_prime(15))# False
  1. 写函数 factorial(n) 计算 n 的阶乘(5! = 120)
deffactorial(n):if n ==0or n ==1:return1 res =1for i inrange(2, n+1): res *= i return res print(factorial(5))# 120
  1. 写函数 sum_of_list(lst),返回列表中所有元素的和
defsum_of_list(lst):returnsum(lst)# 最简单# 或者自己写循环# s = 0# for x in lst: s += x# return s
  1. 写一个函数,接收一个整数 n,打印 1 到 n 的斐波那契数列(前两个数是1,1)
deffib(n):if n <=0:return a, b =1,1print(a, end=" ")if n ==1:returnprint(b, end=" ")for _ inrange(3, n+1): a, b = b, a + b print(b, end=" ") fib(10)# 1 1 2 3 5 8 13 21 34 55
  1. 写函数 count_vowels(s),统计字符串中元音字母个数(a e i o u,不区分大小写)
defcount_vowels(s): s = s.lower()returnsum(1for c in s if c in"aeiou")print(count_vowels("Hello World"))# 3
  1. 有一个字典 d = {“name”:“小明”, “age”:18, “city”:“北京”},写代码把所有 key-value 打印成 “key: value” 格式
d ={"name":"小明","age":18,"city":"北京"}for k, v in d.items():print(f"{k}: {v}")
  1. 写一个函数 remove_duplicates(lst),去掉列表中的重复元素,保持原有顺序
defremove_duplicates(lst): seen =[]for x in lst:if x notin seen: seen.append(x)return seen print(remove_duplicates([1,2,2,3,1,4,5,5]))# [1,2,3,4,5]
  1. 写一个猜数字小游戏(电脑随机1-100,玩家猜,给出太大/太小/恭喜)
import random answer = random.randint(1,100) guess =0 count =0while guess != answer: guess =int(input("猜一个1-100的数字:")) count +=1if guess > answer:print("太大了!")elif guess < answer:print("太小了!")else:print(f"恭喜!猜对了!用了{count}次")
  1. 综合练习:输入一个正整数 n,输出 n 以内所有素数的列表
defget_primes(n): primes =[]for num inrange(2, n+1): is_prime =Truefor i inrange(2,int(num**0.5)+1):if num % i ==0: is_prime =Falsebreakif is_prime: primes.append(num)return primes n =int(input("输入 n:"))print(get_primes(n))

做完这30题,你就基本掌握了 Python 的变量、运算、条件、循环、字符串、列表、函数、简单算法这些最核心的基础。

下一阶段推荐练习方向(按兴趣选):

  • 列表推导式 + 字典 + 集合(再做20题)
  • 文件读写(读写txt、csv)
  • 简单爬虫(requests + beautifulsoup)
  • pygame 小游戏
  • pandas 基础数据处理

你现在做到第几题了?遇到哪道最卡壳?可以贴代码,我帮你 debug~

Read more

Day 93:【99天精通Python】终极项目 - AI 聊天机器人 (下) - 前端界面与部署

Day 93:【99天精通Python】终极项目 - AI 聊天机器人 (下) - 前端界面与部署 前言 欢迎来到第93天! 在过去的两个章节中,我们已经搭建了一个功能强大的后端: * 支持流式对话和多轮记忆。 * 支持上传 PDF 作为知识库进行 RAG 问答。 今天,我们要为这个强大的"大脑"配上一副漂亮的"面孔"。我们将使用原生 HTML, CSS, JavaScript 编写一个聊天界面,并学习如何将整个项目部署上线。 本节内容: * 聊天界面 HTML 结构 * CSS 美化 * JavaScript 核心逻辑 (EventSource) * 文件上传交互 * 项目最终部署 一、HTML 骨架 (templates/

By Ne0inhk
Python爬虫(11)Python数据存储实战:深入解析NoSQL数据库的核心应用与实战

Python爬虫(11)Python数据存储实战:深入解析NoSQL数据库的核心应用与实战

目录 * 引言 * 一、背景:为什么选择NoSQL存储爬虫数据? * 1.1 爬虫数据的核心挑战 * 1.2 NoSQL数据库的核心优势 * 二、NoSQL数据库在爬虫中的核心应用 * 2.1 MongoDB:文档型数据库的王者 * 2.2 Redis:内存数据库的极致性能 * 三、NoSQL选型与性能优化策略 * 3.1 数据库选型对比 * 3.2 性能优化实战技巧 * 四、总结与未来趋势 * 4.1 核心总结 * Python爬虫相关文章(推荐) 引言 在Python爬虫开发中,数据存储的效率和扩展性直接决定了项目的长期价值。传统关系型数据库(如MySQL)虽然支持事务和复杂查询,但在应对‌动态数据结构‌、‌海量数据存储‌和‌高并发写入‌时往往捉襟见肘。而‌NoSQL数据库‌

By Ne0inhk
标准 Python 项目结构

标准 Python 项目结构

理解 Python 项目的通用结构对于初学者来说非常重要。虽然每个项目可能略有不同,但大多数规范、可维护的 Python 项目都遵循一些常见的组织模式。 常见的项目结构如下: my_project/ # 项目根目录 ├── my_package/ # 主要 Python 包(模块集合) │ ├── __init__.py # 标识这是一个 Python 包 │ ├── core.py # 核心逻辑 │ ├── utils.py # 工具函数 │ └── ... # 其他模块 ├── tests/ # 单元测试目录 │ ├── __init__.py │ ├── test_core.py │ └── test_utils.py ├── docs/ # 文档(可选) ├── examples/ # 使用示例(可选) ├── requirements.txt # 依赖列表 ├── setup.

By Ne0inhk

Python 零基础学习指南

Python 零基础学习指南 🐍 从零开始,轻松掌握Python - 最适合初学者的Python学习路径 📋 目录导航 * 第1章:Python简介与环境搭建 * 第2章:基础语法入门 * 第3章:数据类型详解 * 第4章:控制流程 * 第5章:函数的世界 * 第6章:面向对象编程 * 第7章:模块和包 * 第8章:文件操作 * 第9章:异常处理 * 第10章:进阶特性 * 实战项目 第1章:Python简介与环境搭建 🤔 什么是Python? 想象一下,如果编程语言是工具,那么Python就像是一把瑞士军刀 - 简单易用,功能强大! Python的特点: * 🎯 简单易学:语法接近自然语言 * 📖 可读性强:代码像写文章一样清晰 * 🌍 应用广泛:从网站到人工智能都能用 * 🆓 完全免费:开源且免费使用 🛠️ 安装Python Windows用户: 1. 访问

By Ne0inhk