优秀的编程知识分享平台

网站首页 > 技术文章 正文

python入门到脱坑 输入与输出—input()函数

nanyue 2025-06-18 23:06:30 技术文章 1 ℃

以下是针对Python初学者的input()函数完整指南,包含基础用法、安全注意事项和实用技巧:


一、基础用法

1. 接收用户输入

name = input("请输入你的名字:")  # 提示语可选
print(f"你好,{name}!")

执行过程

  1. 程序暂停,等待用户输入
  2. 用户按回车后,输入内容以字符串形式返回
  3. 继续执行后续代码

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)需配置运行模式,建议:

  1. 使用终端运行脚本
  2. 或在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}

八、扩展知识

  1. 文件重定向输入
# 终端执行(将文件内容作为输入)
python script.py < input.txt
  1. 跨平台回车符处理
# 统一换行符为\n
user_input = input().replace('\r', '')
  1. 历史记录功能
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()后,下一步可以学习:

  1. 命令行参数解析(argparse模块)
  2. 图形界面输入(如tkinter)
  3. 网络请求输入(requests获取API数据)
最近发表
标签列表