百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

如何在 Linux 中创建自己的命令? linux 创建sh

ztj100 2024-12-23 14:53 11 浏览 0 评论

在本文中,让我们了解如何在 Linux 中创建您自己的命令,创建一个属于自己的别名命令。

Linux 中的 Alias 命令是什么?

该alias命令提供一个字符串值,用于在遇到命令名称时替换它。
该alias命令允许您为长命令创建快捷方式,使它们更易于记忆和使用。它将具有与运行整个命令相同的功能。

如何创建自己的 Linux 命令

使用该alias命令,您将能够创建自己的命令。创建自己的命令非常简单。
下面是该命令的语法alias:

alias [alias-name[=string]...]

让我们看一个创建您自己的命令的示例。

假设您要创建一个名为 的命令cdv,并且在终端中输入该命令应该会将您带到该Videos目录。

通常,要导航到目录,我们使用cd命令。要导航到Videos我们需要使用cd Videos如下屏幕截图所示:

让我们创建我们的命令cdv来导航到Videos目录。为此,您必须在终端中输入以下命令:

alias cdv="cd Videos"


我们已经创建了我们的命令。从上面的截图中,你可以看到它没有返回任何东西。

但是,我们如何验证命令是否已创建并且正在运行?

只有一种方法可以验证命令是否有效:那就是执行创建的命令。

在终端上运行 cdv 命令,看看会发生什么:


起作用了,直接进入了Videos目录,这样你就创建了自己的命令。

如何查看创建的别名命令

创建几个命令后,您可能会有以下问题:

假设我创建了多个别名命令。我怎样才能一起查看所有这些?如何查看别名的等效命令?

-p您可以通过将标志附加到命令来查看所有别名命令,alias如下所示:

alias -p

查看所有alias命令


我创建了许多别名命令。从上面的屏幕截图中,您可以看到我创建的所有别名命令。

如何在 Linux 中删除别名命令

将您的别名unalias作为参数传递给命令以删除别名命令。

unalias alias_name


如何在 Linux 中删除所有别名命令

假设您已经添加了大约 20 个别名命令。一段时间后,您意识到使用别名命令会使您长期忘记其他命令。由于担心,您希望删除所有别名命令。
我们有一个命令来实现这一点:

unalias -a


您可能想知道更多关于我在上面的段落中写的一件事。

“过了一段时间,你意识到使用别名命令会让你从长远来看忘记其他命令”这是你应该担心的事情吗?这会发生吗?

你的第一个问题的答案是,是的。当您学习和尝试别名命令时,您肯定会有这种感觉。因为我也有同样的感觉。

你的第二个问题的答案是,绝对不会。这将提高生产率。您很可能会忘记您创建的命令,但您永远不会忘记原始命令。所以我总是建议经常重新访问您的别名命令,并确保您正在使用您创建的所有别名命令。

我有一个令人震惊的惊喜给你。打开一个终端窗口并创建一个别名命令(我们将使用cdv上面创建的命令)。打开另一个终端窗口并cdv在其中键入命令。


终端命令显示不存在的别名命令的输出惊讶吗?

是的。如果您创建别名命令,它将仅对终端的特定实例有效。它不会永久创建,因此您将无法在两个不同的终端窗口中访问它,除非您alias在两个终端上运行该命令。

如何创建永久别名命令

要创建永久alias命令,您必须将别名命令添加到 shell 配置文件中。有许多 shell 配置可用。一些著名的 shell 是:

  • Bash - ~/.bashrc
  • Zsh - ~/.zshrc
  • Fish - ~/.config/fish/config.fish

大多数 Linux 发行版都使用bash,所以让我们看看在 bash shell 中创建一个永久别名。其他 shell 的工作原理几乎相同。

让我们.bashrc使用 Vim 打开文件。

sudo vim ~/.bashrc

导航到文件底部,然后按i进入插入模式。添加要永久添加的别名命令。

alias cdv="cd Videos"

按Esc键并输入保存并退出 Vim :wq。

每次更改 shell 配置文件时,都必须重新加载该文件才能使更改立即生效。

默认情况下,您从现在开始打开的所有终端窗口都将包含您的别名命令。


可以打开多个窗口,输入alias -p命令查看。

尝试一些有用的别名命令

在我工作的公司,我们遵循共同的别名命令,我们在入职时在每个人的机器上设置这些命令。如果人们希望添加自己的命令,他们将能够这样做,并且不会反映给其他人(考虑到 OCP 原则)。我们觉得使用这些命令非常有效率。


别名命令

原始命令

描述


f

cd $1

前进。导航到下一个指定目录


b

cd ..

向后走。返回 1 个目录


c

code ./

在当前目录中打开 Visual Studio Code


e

exit

关闭终端选项卡/窗口


home

cd ~

导航到主目录


a

xdotool key ctrl+shift+t

打开一个新的终端选项卡


cbd

cd -

转到您之前所在的最后一个目录


gst

git status

查找 git repo 的状态


gpr

git pull -r

拉取并变基 git 提交


glo

git log --oneline

在单个简化行中显示 git 提交日志


gcl

git config -l

显示当前 repo 的 git 配置


gca

git commit --amend

将当前更改添加到现有提交


gcane

git commit --amend --no-edit

在不编辑现有提交消息的情况下将当前更改添加到现有提交


ad

~/Android/Sdk/emulator/emulator -list-avds

显示可用的安卓模拟器


off

sudo /opt/lampp/lampp stop
poweroff
systemctl poweroff -i

关掉你的机器


bb

if [ -z "$1" ]
then
b;b
else
for (( i=0;i<$1;i++ ))
do
b
done
fi

它是 go back 命令的高级版本。输入b命令只返回一个目录。但是输入 bb 会返回到 2 个目录。如果你想返回 5 个目录,运行 bb 5命令


pokill

kill $(lsof -t -i:$1)

杀死端口上运行的程序


cc

sudo nano ~/x-commands/aliasCommands.sh

编辑别名命令文件


bc

sudo nano ~/.bashrc

编辑.bashrc文件


scc

source ~/x-commands/aliasCommands.sh

更新别名命令后刷新终端


bcc

source ~/.bashrc

.bashrc更新文件后刷新终端


welcome

echo Welcome to shell automation
echo Enter Your Name
read testName
echo Welcome to new shortcut world ~~ $testName ~~ Enjoy Coding....

验证别名命令安装是否正确完成

如何在单个别名命令中运行多个命令

您可以通过两种方式实现这一目标。让我在这里解释一下。

让我们通过一个例子来学习这个。

假设您必须创建一个名为gohome. 运行此命令应将您带到主目录并显示“导航到主目录”消息。

方法#1:

这种方式是添加命令的常用方式alias。您必须添加以分号 ( ;) 分隔的两个命令。

alias gohome="cd ~/;echo Navigated to home directory"


方法#2

这是一种不同的方式。为此,您必须对文件进行更改.bashrc。您必须在.bashrc文件中定义一个函数,并在其中嵌套所有命令。

使用 Vim打开.bashrc文件。

sudo vim ~/.bashrc

按i键进入插入模式。

gohome创建一个以上述 2 个命令命名的函数。

function gohome() {
cd ~/
echo Navigated to home directory
}


 通过按下 键并在命令模式下Esc
键入来保存并退出 Vim 。:wq

通过运行重新加载终端source ~/.bashrc,您现在就可以验证gohome命令了。


注意:创建函数不会在运行alias -p命令时将其列为别名命令。

结论

在本文中,您学习了如何在 Linux 中创建自己的命令。

使用别名命令肯定会提高您的工作效率。在看到许多人使用别名命令后,我见证了他们的指数级增长。我建议你们都设置自己的别名命令。

如何在 Linux 中创建自己的命令?(linux alias命令详解)  弱电智能网

相关推荐

Vue 技术栈(全家桶)(vue technology)

Vue技术栈(全家桶)尚硅谷前端研究院第1章:Vue核心Vue简介官网英文官网:https://vuejs.org/中文官网:https://cn.vuejs.org/...

vue 基础- nextTick 的使用场景(vue的nexttick这个方法有什么用)

前言《vue基础》系列是再次回炉vue记的笔记,除了官网那部分知识点外,还会加入自己的一些理解。(里面会有部分和官网相同的文案,有经验的同学择感兴趣的阅读)在开发时,是不是遇到过这样的场景,响应...

vue3 组件初始化流程(vue组件初始化顺序)

学习完成响应式系统后,咋们来看看vue3组件的初始化流程既然是看vue组件的初始化流程,咋们先来创建基本的代码,跑跑流程(在app.vue中写入以下内容,来跑流程)...

vue3优雅的设置element-plus的table自动滚动到底部

场景我是需要在table最后添加一行数据,然后把滚动条滚动到最后。查网上的解决方案都是读取html结构,暴力的去获取,虽能解决问题,但是不喜欢这种打补丁的解决方案,我想着官方应该有相关的定义,于是就去...

Vue3为什么推荐使用ref而不是reactive

为什么推荐使用ref而不是reactivereactive本身具有很大局限性导致使用过程需要额外注意,如果忽视这些问题将对开发造成不小的麻烦;ref更像是vue2时代optionapi的data的替...

9、echarts 在 vue 中怎么引用?(必会)

首先我们初始化一个vue项目,执行vueinitwebpackechart,接着我们进入初始化的项目下。安装echarts,npminstallecharts-S//或...

无所不能,将 Vue 渲染到嵌入式液晶屏

该文章转载自公众号@前端时刻,https://mp.weixin.qq.com/s/WDHW36zhfNFVFVv4jO2vrA前言...

vue-element-admin 增删改查(五)(vue-element-admin怎么用)

此篇幅比较长,涉及到的小知识点也比较多,一定要耐心看完,记住学东西没有耐心可不行!!!一、添加和修改注:添加和编辑用到了同一个组件,也就是此篇文章你能学会如何封装组件及引用组件;第二能学会async和...

最全的 Vue 面试题+详解答案(vue面试题知识点大全)

前言本文整理了...

基于 vue3.0 桌面端朋友圈/登录验证+60s倒计时

今天给大家分享的是Vue3聊天实例中的朋友圈的实现及登录验证和倒计时操作。先上效果图这个是最新开发的vue3.x网页端聊天项目中的朋友圈模块。用到了ElementPlus...

不来看看这些 VUE 的生命周期钩子函数?| 原力计划

作者|huangfuyk责编|王晓曼出品|CSDN博客VUE的生命周期钩子函数:就是指在一个组件从创建到销毁的过程自动执行的函数,包含组件的变化。可以分为:创建、挂载、更新、销毁四个模块...

Vue3.5正式上线,父传子props用法更丝滑简洁

前言Vue3.5在2024-09-03正式上线,目前在Vue官网显最新版本已经是Vue3.5,其中主要包含了几个小改动,我留意到日常最常用的改动就是props了,肯定是用Vue3的人必用的,所以针对性...

Vue 3 生命周期完整指南(vue生命周期及使用)

Vue2和Vue3中的生命周期钩子的工作方式非常相似,我们仍然可以访问相同的钩子,也希望将它们能用于相同的场景。...

救命!这 10 个 Vue3 技巧藏太深了!性能翻倍 + 摸鱼神器全揭秘

前端打工人集合!是不是经常遇到这些崩溃瞬间:Vue3项目越写越卡,组件通信像走迷宫,复杂逻辑写得脑壳疼?别慌!作为在一线摸爬滚打多年的老前端,今天直接甩出10个超实用的Vue3实战技巧,手把...

怎么在 vue 中使用 form 清除校验状态?

在Vue中使用表单验证时,经常需要清除表单的校验状态。下面我将介绍一些方法来清除表单的校验状态。1.使用this.$refs...

取消回复欢迎 发表评论: