
本教程旨在介绍一种实用的方法,通过简单的Bash脚本,实现Python源代码的显示与脚本执行输出的同步记录。这种方法能够帮助开发者在调试、文档生成或代码审查时,清晰地追踪脚本的输入(源代码)和输出(执行结果),有效解决了标准Python执行方式只显示输出而不显示源代码的问题。
引言:Python脚本执行与日志记录的需求
在Python开发过程中,我们经常需要运行脚本来验证功能或观察输出。然而,标准的Python解释器执行(例如 python your_script.py)通常只会在终端显示脚本的执行结果,而不会显示脚本本身的源代码。这对于需要同时审查输入代码和对应输出的场景(如教学示例、自动化测试日志、生成包含代码块的报告)来说,是一个不便之处。
开发者有时期望获得类似于Python交互式会话的输出格式,即每行输入代码后紧跟着其执行结果,并带有 >>> 或 ... 提示符。虽然完全模拟交互式会话需要更复杂的机制,但本教程将提供一个简洁高效的Bash脚本方案,能够先完整展示Python脚本的源代码,然后执行该脚本并显示其输出,从而满足“同步显示源代码和输出”的核心需求。
核心解决方案:利用Bash脚本组合cat和python命令
要实现先显示源代码再显示执行输出,我们可以利用Linux/Unix系统中的两个基本命令:cat(用于显示文件内容)和 python(用于执行Python脚本)。通过一个简单的Bash脚本将这两个命令结合起来,即可达到目的。
立即学习“Python免费学习笔记(深入)”;
1. 创建Bash脚本
首先,创建一个名为 run_and_log.sh 的文件,并添加以下内容:
#!/bin/sh
# 检查是否提供了Python文件作为参数
if [ -z "$1" ]; then
echo "用法: $0 <python_文件路径>"
echo "示例: $0 my_script.py"
exit 1
fi
PYTHON_FILE="$1"
echo "--- Python 源代码开始 ---"
# 使用cat命令显示Python文件的内容
cat "${PYTHON_FILE}"
echo "--- Python 源代码结束 ---"
echo "" # 添加空行以分隔源代码和输出
echo "--- 脚本执行输出开始 ---"
# 使用python命令执行Python文件
python "${PYTHON_FILE}"
echo "--- 脚本执行输出结束 ---"登录后复制
2. 脚本解析
- #!/bin/sh: 这是一个shebang,指定该脚本应由 /bin/sh(通常是Bash的符号链接)解释执行。
- if [ -z "$1" ]; then ... fi: 这段代码用于检查脚本是否收到了一个命令行参数。$1 代表第一个参数,-z 检查字符串是否为空。如果为空,则打印使用说明并退出。
- PYTHON_FILE="$1": 将第一个命令行参数(即Python文件名)赋值给变量 PYTHON_FILE,方便后续使用。
- echo "--- Python 源代码开始 ---" 等:这些是简单的 echo 命令,用于在输出中添加分隔符和说明,提高可读性。
- cat "${PYTHON_FILE}": 这是关键一步,cat 命令会将指定Python文件的全部内容输出到标准输出,从而在终端显示源代码。
- python "${PYTHON_FILE}": 在 cat 命令执行完毕后,python 命令会执行相同的Python文件,其产生的任何输出(如 print() 语句的结果、错误信息等)也将被打印到标准输出。
3. 使用方法
按照以下步骤来运行您的Python脚本并查看其源代码和输出:
标签: linux python 工具 unix python脚本
还木有评论哦,快来抢沙发吧~