Google Colab 控制台中的 Shell 变量

问题描述

我正在使用 Google Colab,我想将这两个文件以今天的日期保存到我的云端硬盘,这似乎不起作用。我该如何解决这个问题?

输入

!read -p "Please enter today's date: " d
!cp f1_${d}.csv "drive/My Drive"
!cp f2_${d}.csv "drive/My Drive"

输出

Please enter today's date: 08-01-21
cp: cannot stat 'f1_/bin/bash8-01-21.csv': No such file or directory
cp: cannot stat 'f2_/bin/bash8-01-21.csv': No such file or directory

我希望输出文件f1_08-01-21.csvf2_08-01-21.csv

解决方法

这不起作用的原因是每个 !command 都在单独的子 shell 中运行。 read -p 运行,然后退出,并且它读取的变量不再可用,类似于如果您关闭并重新打开笔记本并尝试评估依赖于您之后未评估的早期代码块的代码块,则会发生什么情况重新启动。

无论如何您都不需要手动输入今天的日期;你的电脑已经知道了。

!cp "f1_$(date +%F).csv" "drive/My Drive"
!cp "f2_$(date +%F).csv" "drive/My Drive"

如果您想要的日期格式不是 %F(即 YYYY-MM-DD),请适应口味。 (但请记住,使用计算机可读格式的日期是有意义的;“2021 年 8 月 2 日”读起来令人愉快,但处理起来却很麻烦。您尝试使用的是 date +%d-%m-%Y,它是容易恢复,但很难例如正确排序。)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...