Skip to main content

神奇的 Linux 命令行字符形状工具 boxes | Linux 中国

本文将教你如何在 Linux 命令行终端中使用 boxes 工具绘制字符形状图形来包装你的文字让其更突出。
现在正值假期,每个 Linux 终端用户都该得到一点礼物。无论你是庆祝圣诞节还是庆祝其他节日,或者什么节日也没有,都没有关系。我将在接下来的几周内介绍 24 个 Linux 命令行小玩具,供你把玩或者与朋友分享。让我们享受乐趣,让这个月过得快乐一点,因为对于北半球来说,这个月有点冷并且沉闷。
对于我要讲述的内容,可能你之前就有些了解。但是,我还是希望我们都有机会学到一些新的东西(我做了一点研究,确保可以分享 24 个小玩具)。
24 个 Linux 终端小玩具中的第一个是叫做 boxes 的小程序。为何从 boxes 说起呢?因为在没有它的情况下很难将所有其他命令礼物包装起来!
在我的 Fedora 机器上,默认没有安装 boxes 程序,但它在我的普通仓库中可以获取到,所以用如下命令就可安装:
  1. $ sudo dnf install boxes -y
如果你在使用其他 Linux 发行版,一般也都可以在默认仓库中找到 boxes
boxes 是我真正希望在高中和大学计算机课程中就使用的实用程序,因为善意的老师要求我在每个源文件、函数、代码块等开头添加一些特定外观的备注信息。
  1. /***************/
  2. /* Hello World */
  3. /***************/
事实证明,一旦你需要在框内添加几行文字,并且格式化的将它们统一风格就会变得很乏味。而 boxes 是一个简单实用程序,它使用 ASCII 艺术风格的字符形状框来包围文本。其字符形状默认风格是源代码注释风格,但也提供了一些其他选项。
它真的很容易使用。使用管道,便可以将一个简短问候语塞进字符形状盒子里。
  1. $ cat greeting.txt | boxes -d diamonds -a c
上面的命令输出结果如下:
  1.        /\          /\          /\
  2.     /\//\\/\    /\//\\/\    /\//\\/\
  3.  /\//\\\///\\/\//\\\///\\/\//\\\///\\/\
  4. //\\\//\/\\///\\\//\/\\///\\\//\/\\///\\
  5. \\//\/                            \/\\//
  6.  \/                                  \/
  7.  /\      I'm wishing you all a       /\
  8. //\\     joyous holiday season      //\\
  9. \\//     and a Happy Gnu Year!      \\//
  10.  \/                                  \/
  11.  /\                                  /\
  12. //\\/\                            /\//\\
  13. \\///\\/\//\\\///\\/\//\\\///\\/\//\\\//
  14.  \/\\///\\\//\/\\///\\\//\/\\///\\\//\/
  15.     \/\\//\/    \/\\//\/    \/\\//\/
  16.        \/          \/          \/
或者玩点更有趣的,比如:
  1. echo "I am a dog" | boxes -d dog -a c
不要惊讶,它将会输出如下:
  1.           __   _,--="=--,_   __
  2.          /  \."    .-.    "./  \
  3.         /  ,/  _   : :   _  \/` \
  4.         \  `| /o\  :_:  /o\ |\__/
  5.          `-'| :="~` _ `~"=: |
  6.             \`     (_)     `/
  7.      .-"-.   \      |      /   .-"-.
  8. .---{     }--|  /,.-'-.,\  |--{     }---.
  9.  )  (_)_)_)  \_/`~-===-~`\_/  (_(_(_)  (
  10. (              I am a dog               )
  11.  )                                     (
  12. '---------------------------------------'
boxes 程序提供了很多选项[1] 用于填充、定位甚至处理正则表达式。你可以在其 项目主页[2] 上了解更多有关 boxes 的信息,或者转到 GitHub[3] 去下载源代码或者贡献你自己的盒子形状。说到此,如果你想给你的提交找个好点子,我已经有了一个想法:为什么不能是一个节日礼物盒子?
  1.          _  _
  2.         /_\/_\
  3.  _______\_\/_/_______
  4. |       ///\\\       |
  5. |      ///  \\\      |
  6. |                    |
  7. |     "Happy pull    |
  8. |       request!"    |
  9. |____________________|
boxes 是基于 GPLv2 许可证的开源项目。
你有特别喜欢的命令行小玩具需要我介绍的吗?这个系列要介绍的小玩具大部分已经落实,但还预留了几个空位置。如果你有特别想了解的可以评论留言,我会查看的。如果还有空位置,我会考虑介绍它的。即使要介绍的小玩具已经有 24 个了,但如果我得到了一些很好的意见,我会在最后做一些有价值的提及。
你可以通过 Drive a locomotive through your Linux terminal[4] 来查看明天会介绍的命令行小玩具。

Comments

Popular posts from this blog

CKA Simulator Kubernetes 1.22

  https://killer.sh Pre Setup Once you've gained access to your terminal it might be wise to spend ~1 minute to setup your environment. You could set these: alias k = kubectl                         # will already be pre-configured export do = "--dry-run=client -o yaml"     # k get pod x $do export now = "--force --grace-period 0"   # k delete pod x $now Vim To make vim use 2 spaces for a tab edit ~/.vimrc to contain: set tabstop=2 set expandtab set shiftwidth=2 More setup suggestions are in the tips section .     Question 1 | Contexts Task weight: 1%   You have access to multiple clusters from your main terminal through kubectl contexts. Write all those context names into /opt/course/1/contexts . Next write a command to display the current context into /opt/course/1/context_default_kubectl.sh , the command should use kubectl . Finally write a second command doing the same thing into ...

OWASP Top 10 Threats and Mitigations Exam - Single Select

Last updated 4 Aug 11 Course Title: OWASP Top 10 Threats and Mitigation Exam Questions - Single Select 1) Which of the following consequences is most likely to occur due to an injection attack? Spoofing Cross-site request forgery Denial of service   Correct Insecure direct object references 2) Your application is created using a language that does not support a clear distinction between code and data. Which vulnerability is most likely to occur in your application? Injection   Correct Insecure direct object references Failure to restrict URL access Insufficient transport layer protection 3) Which of the following scenarios is most likely to cause an injection attack? Unvalidated input is embedded in an instruction stream.   Correct Unvalidated input can be distinguished from valid instructions. A Web application does not validate a client’s access to a resource. A Web action performs an operation on behalf of the user without checkin...