如何在 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 | 关掉你的机器 | |
bb | if [ -z "$1" ] | 它是 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 | 验证别名命令安装是否正确完成 |
如何在单个别名命令中运行多个命令
您可以通过两种方式实现这一目标。让我在这里解释一下。
让我们通过一个例子来学习这个。
假设您必须创建一个名为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 中创建自己的命令。
使用别名命令肯定会提高您的工作效率。在看到许多人使用别名命令后,我见证了他们的指数级增长。我建议你们都设置自己的别名命令。
相关推荐
- 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...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Vue 技术栈(全家桶)(vue technology)
- vue 基础- nextTick 的使用场景(vue的nexttick这个方法有什么用)
- vue3 组件初始化流程(vue组件初始化顺序)
- vue3优雅的设置element-plus的table自动滚动到底部
- Vue3为什么推荐使用ref而不是reactive
- 9、echarts 在 vue 中怎么引用?(必会)
- 无所不能,将 Vue 渲染到嵌入式液晶屏
- vue-element-admin 增删改查(五)(vue-element-admin怎么用)
- 最全的 Vue 面试题+详解答案(vue面试题知识点大全)
- 基于 vue3.0 桌面端朋友圈/登录验证+60s倒计时
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)