Linux:终端提示符 (prompt) 不如期生效原因

前言

先来简单介绍下, prompt是什么鬼? 顾名思义就是提示符的意思, 看起来和我们遥远, 但实际上只要是每个接触shell的童鞋, 都有看到, 那就是我们在输命令时前面的那串提示符.

例如:

当然, 这个样式是可以修改的, 这就涉及到我们的PS1PS2了, 有经验或者以前有设置过的童鞋估计都不会陌生, 木有接触过的童鞋可以参考一下链接学习下: linux PS1 提示符定义

问题

因为上面的并不是这次的主题, 所以简单跳过. 其实我们的prompt除了能够展示这些信息之外, 还能够展示些较为'动态'的东西.

我们先来看个需求(简单):

想要在每次执行命令时, 看到当前的时间

所以我们可以在~/.bash_profile里面加入下面的内容:

export PS1="$(date +"%Y-%m-%d %H:%M:%S")\$ "

如代码所示, 应该能够在提示符上看到我们的时间, 现在试验下:

正如我们猜测的一样, 提示符那边已经变成了我们的时间了, 但是貌似出现了一个问题, 当我们在执行下一条命令时, 时间却没有改变, 还是40秒, 哪怕我们多执行几次还是这样.

难道PS1只能加载一次? 但是这个原因很快就被否决, 因为当我们在切换用户时, 提示符的$会改变成#, 而且也有其他的例子(下面会举出来)证明, PS1是每次都会执行的. 所以问题只能在于我们写法中.

考虑到是不是写死命令的缘故, 于是就把date命令放到函数中, 看能否成功: 修改~/.bash_profile文件如下:

echo_time(){
    date +"%Y-%m-%d %H:%M:%S"
}
export PS1="$(echo_time)\$ "

结果是失败的, 貌似这样的用法也是不行的! 查阅了很多文档, 直到看到一篇文章说, 两边必须是单引号, 才恍然大悟, 开始有点理解为什么我的效果会失败.

可能这里会有童鞋不清楚linux的单引号双引号的区别, 简单来说就是:

双引号: 让大部分的符号(例如*), 失去意义,变为普通的字符.
单引号: 让所有的符号, 都失去意义, 变为普通的字符.

举个简单的例子, echo "$a", 可以得出变量a的值, 但是echo '$a', 就真的只能输出$a. 具体的细节, 可以查阅<shell十三问>.

原因分析

所以我这边失败的原因就是, 我这里需要用的是单引号, 而不是双引号, 因为如果用双引号, PS1在赋值时, 就已经获得命令/函数的值了, 所以每次打印PS1, 都已经是具体的值了, 而不是一个命令/函数. 就好像:

# 双引号:
PS1="$(date +%F)"  取出来的结果就是: PS1="2017-07-24"

# 单引号:
PS1='$(date +%F)'  取出来的结果就是: PS1='$(date +%F)'

所以等到在终端输出时, 就会有不同的表现: 单引号, 每次输出, 都是执行那个函数, 而双引号, 因为已经是固定字符了, 所以每次都是那个值!

解决方案

找到了原因, 修改起来就得心应手了, 我们只需要将刚才的语法, 从双引号换成单引号即可.

修改~/.bash_profile

echo_time(){
    date +"%Y-%m-%d %H:%M:%S"
}

export PS1='$(echo_time)\$ '

可以看到这里已经是完美解决了我们的问题了~

PS: 附上一个小小的福利 需求:     如果长期在终端下开发, 而且又是gitlab的专用户的童鞋, 很多时候都会担心自己开发的代码分支会搞错, 或者不记得自己所处的分支是啥, 经常就会需要git branch来看下, 现在我们可以通过这个, 来解决我们这个难题~

修改~/.bash_profile

# 获取代码的分支
get_branch(){
   BRANCH=`git branch 2>/dev/null |sed -n '/^\*/s/^\* //p'`
   if [[ -n $BRANCH ]]
   then
        echo " [*$BRANCH]"
   else
        echo ''
   fi
}
export PS1='\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;36m\]\W\[\033[00m\]\[\033[01;32m\]$(get_branch)\[\033[00m\] \$ '

运行的效果:

可以看到, 当我进入一个代码目录时, 我的提示符就会展示出所处的分支~, 这功能虽小, 但我觉得还是挺有用的, 就跟git bash客户端类似, 希望大家喜欢!

欢迎各位大神指点交流, QQ讨论群: 258498217

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏软件开发

前端MVC学习总结(二)——AngularJS验证、过滤器、指令

一、验证 angularJS中提供了许多的验证指令,可以轻松的实现验证,只需要在表单元素上添加相应的ng属性,常见的如下所示: <input Type="tex...

2386
来自专栏owent

初识Rust

虽然我主要使用C++,但是最近也想学点现代化的新语言。初步想的是从golang和Rust里先选一个。

1864
来自专栏逍遥剑客的游戏开发

Tiled源码分析(三): Undo/Redo实现

3177
来自专栏web前端教室

9.6,*少芳-学习笔记【web前端零基础课】

在学习一些js内容后,完成了一部分网站首页的动作设置(搜索栏、侧边栏、轮播图),对js代码进行了封装,重新整理了js文件。(index.js\ma...

1237
来自专栏日常学python

数据抓取实践:对加密参数及压缩混淆 JS 的逆向分析

本文会介绍几种分析技巧,需要一点前端知识(总感觉在前端做防爬没什么意义,因为源码都是公开的)。文末附上爬虫 Demo 验证,虽然对于这个案例来说使用 Selen...

4790
来自专栏Golang语言社区

说说JSON和JSONP,也许你会豁然开朗-转

今天在写底层通信框架的时候,遇到了跨域的问题;随便给不知道的童鞋们分享下基础知识。 前言   由于Sencha Touch 2这种开发模式的特性,基本...

3986
来自专栏程序员宝库

精读《高性能 javascript》

本期我来给大家推荐的书是《高性能JavaScript》,在这本书中我们能够了解 javascript 开发过程中的性能瓶颈,如何提升各方面的性能,包括代码的加载...

1132
来自专栏Jerry的SAP技术分享

JavaScript面试系列:JavaScript设计模式之桥接模式和懒加载

Java程序员面试系列-什么是Java Marker Interface(标记接口)

782
来自专栏前端杂货铺

History API与浏览器历史堆栈管理

移动端开发在某些场景中有着特殊需求,如为了提高用户体验和加快响应速度,常常在部分工程采用SPA架构。传统的单页应用基于url的hash值进行路由,这种实现不存在...

4965
来自专栏jianhuicode

上手React Native--常用属性介绍

这几天打算学习并实践ReactNative,学习记录中有不对的地方请大家指出来,互相交流。(-_-)   关于学习ReactNative需要准备的基础知识,①...

2537

扫码关注云+社区

领取腾讯云代金券