网站首页 > 精选文章 正文
以下是针对Python初学者的input()函数完整指南,包含基础用法、安全注意事项和实用技巧:
一、基础用法
1. 接收用户输入
name = input("请输入你的名字:") # 提示语可选
print(f"你好,{name}!")
执行过程:
- 程序暂停,等待用户输入
- 用户按回车后,输入内容以字符串形式返回
- 继续执行后续代码
2. 多行输入提示
prompt = """请填写信息:
用户名:"""
username = input(prompt)
二、类型转换处理
input()始终返回字符串,需手动转换类型:
# 安全转换示例
try:
age = int(input("你的年龄:")) # 转换为整数
height = float(input("身高(米):")) # 转换为浮点数
except ValueError:
print("请输入有效数字!")
三、实用技巧
1. 设置默认值
from getpass import getpass
password = getpass("请输入密码:") # 输入时不会显示内容
3. 超时自动取消
import signal
def timeout_handler(signum, frame):
raise TimeoutError("输入超时")
signal.signal(signal.SIGALRM, timeout_handler)
signal.alarm(5) # 5秒超时
try:
data = input("请在5秒内输入:")
except TimeoutError:
print("\n时间到!")
finally:
signal.alarm(0) # 取消计时器
四、安全注意事项
1. 永远不要直接eval输入
# 危险!用户可以输入恶意代码
x = eval(input("输入计算式:")) # 若输入__import__('os').system('rm -rf /')会引发灾难
# 安全替代方案
import ast
safe_data = ast.literal_eval(input("输入列表/字典:")) # 仅支持基础数据结构
2. 防注入处理(数据库操作)
# 错误示范(SQL注入风险)
user_input = input("用户名:")
query = f"SELECT * FROM users WHERE name = '{user_input}'"
# 正确做法(使用参数化查询)
cursor.execute("SELECT * FROM users WHERE name = %s", (user_input,))
五、输入验证模板
def get_valid_input(prompt, validate_func, error_msg):
while True:
user_input = input(prompt)
if validate_func(user_input): # 验证函数返回True/False
return user_input
print(error_msg)
# 使用示例:只接受数字
phone = get_valid_input(
"手机号:",
lambda x: x.isdigit() and len(x) == 11,
"请输入11位数字手机号!"
)
六、常见问题解答
Q1: 如何输入多个值?
# 方法1:用split分割
data = input("输入两个数字(空格分隔):").split()
a, b = map(float, data) # 转换为数值
# 方法2:多次input
a = float(input("第一个数字:"))
b = float(input("第二个数字:"))
Q2: 为什么input()在IDE中不显示提示?
某些IDE(如PyCharm)需配置运行模式,建议:
- 使用终端运行脚本
- 或在IDE设置中启用"模拟终端"
Q3: 如何清空输入缓冲区?
import sys
sys.stdin.flush() # 清空标准输入缓存
七、实际应用案例
1. 简易计算器
try:
expr = input("输入算式(如3+5):")
result = eval(expr) # 实际开发应用更安全的计算库
print(f"结果:{result}")
except:
print("无效输入")
2. 用户注册流程
def register():
username = input("设置用户名:").strip()
while not username.isalnum(): # 只允许字母数字
print("用户名只能包含字母和数字")
username = input("重新输入:").strip()
password = getpass("设置密码:")
return {"username": username, "password": password}
八、扩展知识
- 文件重定向输入:
# 终端执行(将文件内容作为输入)
python script.py < input.txt
- 跨平台回车符处理:
# 统一换行符为\n
user_input = input().replace('\r', '')
- 历史记录功能:
import readline # Unix-like系统可用
while True:
cmd = input(">>> ")
if cmd == "history":
for i in range(readline.get_current_history_length()):
print(readline.get_history_item(i + 1))
掌握input()后,下一步可以学习:
- 命令行参数解析(argparse模块)
- 图形界面输入(如tkinter)
- 网络请求输入(requests获取API数据)
猜你喜欢
- 2025-08-06 CRLF injection
- 2025-08-06 十八.XSS跨站脚本攻击原理及代码攻防演示(一)
- 2025-08-06 Unicode,GBK和UTF8
- 2025-08-06 运维超实用:命令行 curl post有变量的json数据
- 2025-08-06 python每天一道面试题25
- 2025-08-06 python——分类统计字符个数
- 2025-08-06 在 Python 中从列表中删除换行符的多种方法
- 2025-08-06 12个python数据处理常用内置函数
- 2025-08-06 三十个常见的python脚本,别再弄错,会吃亏的,附视频教程
- 2025-08-06 「oeasy」python0020换行字符_feed_line_lf_反斜杠n_B语言_安徒生
- 08-06如何实现服务器架构优化?
- 08-06快速搭建一个自己的邮箱服务器
- 08-06超强 useMCP() 钩子来了,3 行代码搞定各种 MCP 服务器!
- 08-066款应该会用的办公软件
- 08-06快速搭建一个本地的FTP服务器
- 08-06Nginx 深度解析指南:一文掌握高性能 Web 服务器秘诀
- 08-06详解Web服务器安全攻击及防护机制
- 08-06163邮箱绑定foxmail邮件客户端使用指南
- 最近发表
- 标签列表
-
- 向日葵无法连接服务器 (32)
- git.exe (33)
- vscode更新 (34)
- dev c (33)
- git ignore命令 (32)
- gitlab提交代码步骤 (37)
- java update (36)
- vue debug (34)
- vue blur (32)
- vscode导入vue项目 (33)
- vue chart (32)
- vue cms (32)
- 大雅数据库 (34)
- 技术迭代 (37)
- 同一局域网 (33)
- github拒绝连接 (33)
- vscode php插件 (32)
- vue注释快捷键 (32)
- linux ssr (33)
- 微端服务器 (35)
- 导航猫 (32)
- 获取当前时间年月日 (33)
- stp软件 (33)
- http下载文件 (33)
- linux bt下载 (33)