Ubuntu运行.sh文件

article/2025/10/20 0:53:36

一、运行.sh文件

(1)使用sh testsh执行
(2)使用bash testsh 执行
(3)使用点 执行
(4)使用source执行./sh 文件开头***的含义:
#!/bin/sh             以下的代码由/bin/sh 来解释
#!/bin/bash           以bash shell来解释
#!/bin/csh            以csh shell来解释
#!/usr/bin/env python  以下代码由python来解释 
#! 是一个约定的标记,它告诉系统这个脚本需要什么解释器来执行,即使用哪
一种 Shell

 

(1)使用sh test.sh执行

使用 sh test.sh 来执行script文件,该方法标明使用 sh 这种shell来执行test.sh文件,sh已经是一种被bash替代的shell.

尽管我们在test.sh中声明使用 #!/bin/bash 来执行我们的文件,但此时使用sh而不是bash,则#!/bin/bash 已不起作用。

(2)使用bash test.sh 执行

该方法其实与 sh test.sh 的原理一样,只是使用了 /bin/bash 该种shell来执行我们的脚本文件。

所以,其实使用 dash test.sh' 也是可以的,只是取决于自己想使用那种shell来执行脚本,

但sh、bash、dash三者有些许差别,对于部分关键字如 let,bash支持,而sh和dash并不支持,对于部分关键字则选择使用bash。

(3)使用点 . 执行

该种方式使用之前必须为文件添加执行的权限:

  chmod +x test.sh

添加完执行权限之后,便可以使用 ./test.sh 来执行脚本,该方式与 bash test.sh 是一样的 ,默认使用 bin/bash 来执行我们的脚本。

只有该种执行方式需要对文件添加执行权限,其他方式并不需要。

(4)使用source执行

使用source则也能够直接执行我们的脚本:

  source test.sh

区别

当我们使用 sh test.sh 、bash test.sh 、 ./test.sh 执行脚本的时候,该test.sh运行脚本都会使用一个新的shell环境来执行脚本内的命令,

也就是说,使用这3种方式时,其实script是在子进程的shell内执行,当子进程完成后,子进程内的各项变量和操作将会结束而不会传回到父进程中。

能否理解?看下面例子:

  1. [root@ubuntu] # bash test.sh
  2. Please input your first name: yao <==输入firstname
  3. Please input your last name: pentonBin <==输入lastname
  4. Your full name is: yao pentonBin
  5. [root@ubuntu] # echo $firstname
  6. <==这里没有输出

如果使用source方法来执行脚本呢?

  1. [root@ubuntu] # source test.sh
  2. Please input your first name: yao <==输入firstname
  3. Please input your last name: pentonBin <==输入lastname
  4. Your full name is: yao pentonBin
  5. [root@ubuntu] # echo $firstname
  6. yao <==这里输出firstname

也就是说,source方法执行脚本是在父进程中执行的,test.sh的各项操作都会在原本的shell内生效,

这也是为什么不注销系统而要让某些写入~/.bashrc的设置生效时,需要使用 source ~/.bashrc 而不能使用 bash ~/.bashrc

二、编写.sh文件

(1) 定义变量:变量名不加美元符号。
如:

Num=1
Var2="hello world!"

 注意:变量名和等号之间不能有空格。

(2) 使用变量:使用一个定义过的变量,只要在变量名前面加美元符号即可.
如:

#!/bin/sh
a="hello world!"
num=2
echo "a is : $a num is : ${num}nd"

运行结果:
a is : hello world! num is : 2nd
说明:变量名外面的花括号是可选的,加不加都行,加花括号是为了帮助解释器识别变量的边界,我们通常加花括号。

(3) 传递参数
我们可以在执行 Shell 脚本时,向脚本传递参数,脚本内获取参数的格式为:$n。
n 代表一个数字,1 为执行脚本的第一个参数,2 为执行脚本的第二个参数,以此类推……
值得注意的是,$0 获取到的是脚本路径以及脚本名,后面按顺序获取参数,
当参数超过10个时(包括10 个),需要使用${10},${11}....才能获取到参数,
但是一般很少会超过10 个参数的情况。

建立脚本文件test.sh

#!/bin/bash
echo "脚本$0"
echo "第一个参数$1"
echo "第二个参数$2"

 调用的时候就可以:sh test.sh 2 3,输出如下:
脚本 test.sh
第一个参数2
第二个参数3

(4) echo 命令: echo 用于字符串的输出,常用于观察系统变量的路径。
显示普通字符串:echo "learn linux"
显示系统库路径:echo $PATH PATH 就是一个系统变量,与windonws 下的环境变量相同,存储
默认库的搜索路径

(5) Shell 脚本文件遍历目录
问题:文件夹 /tmp 遍历

#!/bin/bash
for i in /tmp/*
doecho "Hello, $i"
done

 

 


http://chatgpt.dhexx.cn/article/rWgGn8aW.shtml

相关文章

Linux下如何运行.sh文件

在Linux系统下运行.sh文件有两种方法&#xff0c; 比如在~/桌面/LoveDA-master/Semantic_Segmentation/scripts目录下有个predict_test.sh文件 第一种&#xff08;这种办法需要用chmod使得文件具备执行条件(x): chmod ux datelog.sh&#xff09;&#xff1a; 1、在任何路径下&…

linux 常用命令之运行.sh文件

linux 常用命令之运行.sh文件 Linux下面用命令如何运行.sh文件的方法 一、直接./加上文件名.sh&#xff0c;如运行hello.sh为./hello.sh【hello.sh必须有x权限】 二、直接sh 加上文件名.sh&#xff0c;如运行hello.sh为sh hello.sh【hello.sh可以没有x权限】 1&#xff1a;当前…

win10下如何运行.sh文件

win10下如何运行.sh文件 确保您使用至少是Windows10的14316版本。 这种方法只适用于64位版本的Windows 10 今天居然惊奇地发现原来win10的功能简直强大到没话说,居然在更新后有一个Linux的子系统,也就是说虚拟机神马的可能慢慢地会消失啦!话不多说啦,抓紧分享一下新鲜出炉的…

Linux系统中运行.sh(Shell脚本)文件

本文转载自&#xff1a;百度经验&#xff1a;Linux下如何运行.sh文件 其中&#xff0c;以绝对路径运行方法&#xff1a; &#xff08;1&#xff09;./home/test/shell/hello.sh&#xff0c;可以这样运行是因为当前登录用户是root&#xff0c;当前路径是在/下&#xff0c;. 代表…

Windows系统下如何运行.sh脚本文件

前言&#xff1a; .sh文件是一种命令脚本文件&#xff0c;在Windows系统下可以通过命令行工具打开运行。通常可以使用Git工具来打开运行.sh脚本文件。不过很多第一次使用Git的人&#xff0c;可能对Git工具不熟悉。.sh文件在命令行运行时是有固定写法的&#xff0c;下面介绍详细…

shell与 .sh文件与 .bash文件

一、shell和bash shell是LInux系统下的解释器&#xff0c;类似于windows下的cmd。shell对用户输入到窗口中的命令行进行解释&#xff0c;输入到内核。 bash同样是Linux系统下的解释器&#xff0c;是bash的改进版。 二、.sh文件与.bash文件 .sh文件和.bash文件都是脚本文件&a…

Linux系统下如何运行.sh文件

在Linux系统下运行.sh文件有两种方法&#xff0c;比如我在root目录下有个datelog.sh文件 第一种&#xff08;这种办法需要用chmod使得文件具备执行条件(x): chmod ux datelog.sh&#xff09;&#xff1a; 1、在任何路径下&#xff0c;输入该文件的绝对路径/root/datelog.sh就可…

Linux 创建.sh脚本文件

1.在你想要放.sh文件的文件夹下&#xff0c;右键打开终端&#xff1a; 2.新建.sh文件,起名xxx touch xxx.sh 3.打开并编辑.sh文件 gedit xxx.sh 4.内容&#xff1a;第一行必须有&#xff0c;其他自己写&#xff0c;以下示例中进入某个文件夹&#xff0c;并执行了一个文件 …

Linux系统中运行.sh文件的几种方法

在Linux系统中执行.sh文件的几种方法&#xff1a; 1. cd到.sh文件所在的目录&#xff0c;然后执行./xxx.sh 【前提&#xff1a;该./sh文件要有可执行的权限&#xff0c;chmod ux xxx.sh】 2. 在任何路径下&#xff0c;输入.sh文件的绝对路径进行执行 【前提&#xff1a;该.sh文…

【Linux中shell命令】.sh文件种种操作

文章目录 Shell基础Shell本身Shell脚本第一个Shell脚本运行Shell脚本有三种方式Shell bash和sh区别.sh文件与.bash文件 Shell内置变量命令evalecho实例分析 .sh脚本自动执行文件一个.sh执行多个程序执行多个.sh Shell基础 Shell本身 Shell 是一个用 C 语言编写的程序&#xf…

linux中.sh文件是什么?怎么执行?

一、linux中.sh文件是什么&#xff1f; linux中.sh文件是脚本文件&#xff0c;一般都是bash脚本。 二、linux中的.sh文件怎么执行&#xff1f; 1、直接./加上文件名.sh&#xff0c;如运行hello.sh为 ./hello.sh 【绝对路径下也可以&#xff0c;但hello.sh必须有x权限】 使用…

什么是分布式计算框架(动画演示)?

分布式计算 是将程序移动到数据段,多个节点并行计算 计算框架 是指实现某项任务或某项工作从开始到结束的计算过程或者流的结构 并行计算框架 将一个大的,复杂的任务拆分成多个小业务,将多个小任务分发到多个节点中,每个节点同时执行计算

分布式计算框架MapReduce架构

Hadoop核心由HDFS和MapReduce组成&#xff0c;HDFS负责分布式存储&#xff0c;MapReduce负责分布式计算。 MapReduce最早是由Google研究提出的一种面向大规模数据处理的并行计算模型和方法&#xff0c;其初衷主要是为了解决搜索引擎中大规模网页数据的并行化处理。由于MapReduc…

分布式计算框架体设计

1概述 本文是描述的是关于“分布式计算框架”(英文全称Distribute Compute Framework,简称DCF)的设计相关内容。为方便起见,以下将系统名称简称为DCF。 DCF内部采用C++语言实现了类MapReduce原理的一套分布式计算机制,力求为用户提供一套高效、稳定、可扩容的分布式计算…

分布式计算框架综述

本来是发表到科技论在线的&#xff0c;谁知道被退稿了&#xff0c;那就发到这里来吧。 0 引言 随着互联网的发展&#xff0c;web2.0时期[1]的到来&#xff0c;人类正式进入了信息爆炸时期的。海量的信息在很多应用都会出现&#xff0c;比如一些社交网络应用中记录用户行为…

大数据理论与实践5 分布式计算框架MapReduce和Spark

MapReduce和Spark MapReduce简介原理示例基本概念作业运行模式 Spark简介概念编程模型RDDRDD操作&#xff08;Operator&#xff09;RDD依赖&#xff08;Dependency&#xff09; 作业运行模式 课后温习参考 MapReduce 简介 MapReduce是一个面向离线批处理的分布式计算框架。 离…

MapReduce(分布式计算框架)了解

Hadoop组成 Hadoop HDFS&#xff1a;一个高可靠、高吞吐量的分布式文件系统&#xff0c;对海量数据的存储。 Hadoop MapReduce&#xff1a;一个分布式的资源调度和离线并行计算框架。 Hadoop Yarn&#xff1a;基于HDFS,用于作业调度和集群资源管理的框架。 本篇将学习分布式并…

深入浅出:HADOOP分布式计算框架

hadoop分布式计算框架详解 1.1 分布式计算框架 1.1.1 编程模型 1. inputformat 在MapReduce 程序的开发过程中&#xff0c;往往需要用到FileInputFormat与TextInputFormat&#xff0c; 我们会发现TextInputFormat 这个类继承自FileInputFormat &#xff0c; FileInputFormat 这…

Hadoop学习之MapReduce分布式计算框架

目录 一、本地模式 1.新建一个本地maven项目 2.修改prom依赖&#xff08;maven&#xff09; 3.新建一个包mapreduce&#xff0c;在该包中新建三个包 4.写mapper组件 5.写Reducer组件 6.写Driver组件 7.运行结果 二、集群模式词频统计 1.准备用于单词计数的文件夹和文…

MapReduce(分布式计算框架)

什么是MapReduce MapReduce是分布式计算框架&#xff0c;它将大型数据操作作业分解为可以跨服务器集群并行执行的单个任务&#xff0c;适用于大规模数据处理场景&#xff0c;每个job包含Map和Reduce两部分 MapReduce的设计思想 分而治之&#xff1a;简化并行计算的编程模型 …