使用 Python 创建你自己的 Shell (上)_python write到shell脚本中(1)

做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。

别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。


(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

(4)200多本电子书

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。

基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。

(5)Python知识点汇总

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。

在这里插入图片描述

(6)其他资料

还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。

在这里插入图片描述

这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

Start the loop here

def main():
shell_loop()

if name == “main”:
main()


接着,在 shell\_loop() 中,为了指示循环是否继续或停止,我们使用了一个状态标志。在循环的开始,我们的 shell 将显示一个命令提示符,并等待读取命令输入。



import sys
SHELL_STATUS_RUN = 1
SHELL_STATUS_STOP = 0
def shell_loop():
status = SHELL_STATUS_RUN
while status == SHELL_STATUS_RUN:
### 显示命令提示符
sys.stdout.write('> ')
sys.stdout.flush()
### 读取命令输入
cmd = sys.stdin.readline()


之后,我们切分命令(tokenize)输入并进行执行(execute)(我们即将实现 tokenize 和 execute 函数)。因此,我们的 shell\_loop() 会是如下这样:



import sys
SHELL_STATUS_RUN = 1
SHELL_STATUS_STOP = 0
def shell_loop():
status = SHELL_STATUS_RUN
while status == SHELL_STATUS_RUN:
### 显示命令提示符
sys.stdout.write('> ')
sys.stdout.flush()
### 读取命令输入
cmd = sys.stdin.readline()
### 切分命令输入
cmd_tokens = tokenize(cmd)
### 执行该命令并获取新的状态
status = execute(cmd_tokens)


这就是我们整个 shell 循环。如果我们使用 python shell.py 启动我们的 shell,它会显示命令提示符。然而如果我们输入命令并按回车,它会抛出错误,因为我们还没定义 tokenize 函数。为了退出 shell,可以尝试输入 ctrl-c。稍后我将解释如何以优雅的形式退出 shell。


![使用 Python 创建你自己的 Shell (上)使用 Python 创建你自己的 Shell (上)](http://www.linuxprobe.com/wp-content/uploads/2016/07/linux-shell_01.jpg "使用 Python 创建你自己的 Shell (上)使用 Python 创建你自己的 Shell (上)")



**步骤 2:命令切分**

**()**当用户在我们的 shell 中输入命令并按下回车键,该命令将会是一个包含命令名称及其参数的长字符串。因此,我们必须切分该字符串(分割一个字符串为多个元组)。咋一看似乎很简单。我们或许可以使用 cmd.split(),以空格分割输入。它对类似 ls -a my\_folder 的命令起作用,因为它能够将命令分割为一个列表 ['ls', '-a', 'my\_folder'],这样我们便能轻易处理它们了。


然而,也有一些类似 echo "Hello World" 或 echo 'Hello World' 以单引号或双引号引用参数的情况。如果我们使用 cmd.spilt,我们将会得到一个存有 3 个标记的列表 ['echo', '"Hello', 'World"'] 而不是 2 个标记的列表 ['echo', 'Hello World']。幸运的是,Python 提供了一个名为 shlex 的库,它能够帮助我们如魔法般地分割命令。(提示:我们也可以使用正则表达式,但它不是本文的重点。)



import sys
import shlex

def tokenize(string):
return shlex.split(string)


然后我们将这些元组发送到执行进程。



**步骤 3:执行**

这是 shell 中核心而有趣的一部分。当 shell 执行 mkdir test\_dir 时,到底发生了什么?(提示: mkdir 是一个带有 test\_dir 参数的执行程序,用于创建一个名为 test\_dir 的目录。)execvp 是这一步的首先需要的函数。在我们解释 execvp 所做的事之前,让我们看看它的实际效果。



import os

def execute(cmd_tokens):
### 执行命令
os.execvp(cmd_tokens[0], cmd_tokens)
### 返回状态以告知在 shell_loop 中等待下一个命令
return SHELL_STATUS_RUN


再次尝试运行我们的 shell,并输入 mkdir test\_dir 命令,接着按下回车键。在我们敲下回车键之后,问题是我们的 shell 会直接退出而不是等待下一个命令。然而,目录正确地创建了。因此,execvp 实际上做了什么?


execvp 是系统调用 exec 的一个变体。第一个参数是程序名字。v 表示第二个参数是一个程序参数列表(参数数量可变)。p 表示将会使用环境变量 PATH 搜索给定的程序名字。在我们上一次的尝试中,它将会基于我们的 PATH 环境变量查找mkdir 程序。(还有其他 exec 变体,比如 execv、execvpe、execl、execlp、execlpe;你可以 google 它们获取更多的信息。)exec 会用即将运行的新进程替换调用进程的当前内存。在我们的例子中,我们的 shell 进程内存会被替换为 mkdir 程序。接着,mkdir 成为主进程并创建 test\_dir 目录。最后该进程退出。


这里的重点在于我们的 shell 进程已经被 mkdir 进程所替换。这就是我们的 shell 消失且不会等待下一条命令的原因。因此,我们需要其他的系统调用来解决问题:fork。fork 会分配新的内存并拷贝当前进程到一个新的进程。我们称这个新的进程为子进程,调用者进程为父进程。然后,子进程内存会被替换为被执行的程序。因此,我们的 shell,也就是父进程,可以免受内存替换的危险。  
 让我们看看修改的代码。...  
 ![外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.png?origin_url=http%3A%2F%2Fwww.linuxprobe.com%2Fwp-content%2Fuploads%2F2016%2F08%2Fdef-execute.png%20%22%E4%BD%BF%E7%94%A8%20Python%20%E5%88%9B%E5%BB%BA%E4%BD%A0%E8%87%AA%E5%B7%B1%E7%9A%84%20Shell%20%EF%BC%88%E4%B8%8A%EF%BC%89%E4%BD%BF%E7%94%A8%20Python%20%E5%88%9B%E5%BB%BA%E4%BD%A0%E8%87%AA%E5%B7%B1%E7%9A%84%20Shell%20%EF%BC%88%E4%B8%8A%EF%BC%89%22&pos_id=img-W2A7sQtA-1715531942829)


当我们的父进程调用 os.fork() 时,你可以想象所有的源代码被拷贝到了新的子进程。此时此刻,父进程和子进程看到的是相同的代码,且并行运行着。如果运行的代码属于子进程,pid 将为 0。否则,如果运行的代码属于父进程,pid 将会是子进程的进程 id。



**一、Python所有方向的学习路线**

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

![img](https://img-blog.csdnimg.cn/1d40facda2b84990b8e1743f5487d455.png)  
![img](https://img-blog.csdnimg.cn/0fc11d4a31bd431dbf124f67f1749046.png)

**二、Python必备开发工具**

工具都帮大家整理好了,安装就可直接上手!![img](https://img-blog.csdnimg.cn/ff266f529c6a46c4bc28e5f895dec647.gif#pic_center)

**三、最新Python学习笔记**

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

![img](https://img-blog.csdnimg.cn/6d414e9f494742db8bcc3fa312200539.png)

**四、Python视频合集**

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

![img](https://img-blog.csdnimg.cn/a806d9b941c645858c61d161aec43789.png)

**五、实战案例**

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。![img](https://img-blog.csdnimg.cn/a353983317b14d3c8856824a0d6186c1.png)

**六、面试宝典**

![在这里插入图片描述](https://img-blog.csdnimg.cn/97c454a3e5b4439b8600b50011cc8fe4.png)

![在这里插入图片描述](https://img-blog.csdnimg.cn/111f5462e7df433b981dc2430bb9ad39.png)

###### **简历模板**![在这里插入图片描述](https://img-blog.csdnimg.cn/646863996ac44da8af500c049bb72fbd.png#pic_center)




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

### 回答1: 可以使用以下步骤将 Python 命令写入 Shell 脚本: 1. 创建一个新的文本文件,例如 `test.sh`。 2. 在文件的第一行添加 `#!/bin/bash`,指定使用Shell。 3. 在下一行添加 Python 命令,例如 `python my_script.py`。 4. 保存并关闭文件。 5. 在终端使用 `chmod +x test.sh` 命令添加可执行权限。 6. 运行脚本使用 `./test.sh` 命令执行。 示例代码如下: ``` #!/bin/bash python my_script.py ``` 注意:在脚本执行 Python 命令需要保证 Python 已经安装在系统,并且 Python 执行文件的路径已经添加到系统的 PATH 环境变量。 ### 回答2: Python可以通过subprocess模块将命令写入shell脚本。subprocess模块在Python用于创建新的进程,可以调用外部命令、程序和脚本。 我们可以使用subprocess模块的Popen函数来执行shell脚本。下面是一个示例代码: ```python import subprocess def write_commands_to_shell_script(commands, script_path): # 打开指定路径的shell脚本文件 with open(script_path, 'w') as script_file: # 将命令逐行写入shell脚本 for command in commands: script_file.write(command + '\n') def execute_shell_script(script_path): # 使用subprocess来执行shell脚本 subprocess.Popen(['bash', script_path]) # 定义要写入shell脚本的命令列表 commands = [ 'echo "Hello, World!"', 'ls -l', 'python myscript.py' ] script_path = 'script.sh' # 将命令写入shell脚本 write_commands_to_shell_script(commands, script_path) # 执行shell脚本 execute_shell_script(script_path) ``` 以上代码,`write_commands_to_shell_script`函数用于将命令逐行写入shell脚本文件,`execute_shell_script`函数使用subprocess模块来执行shell脚本。 你可以根据需要调整`commands`列表的命令内容,将其写入到shell脚本文件,然后执行该脚本。这样就能够使用Python将命令写入到shell脚本。 ### 回答3: Python可以将命令写入Shell脚本以实现自动化操作。Shell脚本是一种文本文件,其包含一系列用Shell语言编写的命令。而Python提供了subprocess模块,可以通过调用系统的Shell来执行命令。 要将命令写入Shell脚本,首先需要使用Python的subprocess模块创建一个新的Shell进程。我们可以使用subprocess模块的Popen函数来实现这一点。Popen函数允许我们执行一个命令,其参数可以是一个shell命令字符串。例如,如果我们要在Shell脚本创建一个名为"test.sh"的文件并写入一些命令,我们可以使用如下代码: ```python import subprocess # 创建一个名为test.sh的Shell脚本文件,并写入命令 with open("test.sh", "w") as f: f.write("#!/bin/bash\n") # 写入Shell脚本头部 f.write("echo 'Hello, World!'\n") f.write("ls -l\n") # 执行Shell脚本 subprocess.Popen(["bash", "test.sh"]) ``` 在上述代码,我们先打开一个名为"test.sh"的文件,并使用write函数将Shell脚本的内容写入其。我们在文件的开头写入了"#!/bin/bash",这是Shell脚本的头部,表示该脚本使用bash作为解释器。 然后,我们使用subprocess.Popen函数创建一个新的Shell进程,并将Shell脚本文件作为参数传递给它。这将在系统的Shell执行我们在脚本写入的命令。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值