shell自定义日志输出函数log

Background

在编写比较复杂的脚本时,需要输出相关日志信息,方便知悉脚本的执行情况以及问题的排查。

源码 log.sh

# 自定义日志函数
function log(){if [[ $1 = "i" || $1 = "info" ]]; thenecho -ne "\033[1;34mINFO: \033[0m"shift && echo -e "$@"elif [[ $1 = "w" || $1 = "warn" ]]; thenecho -ne "\033[1;33mWARN: \033[0m"shift && echo -e "$@"elif [[ $1 = "s" || $1 = "success" ]]; thenecho -ne "\033[1;32mSUCCESS: \033[0m"shift && echo -e "$@"elif [[ $1 = "e" || $1 = "error" ]]; thenecho -ne "\033[1;31mERROR: \033[0m"shift && echo -e "$@"elsecolors=$1input=$2opt='-e'rightpattern='true'if [[ ${colors:0:1} = "n" ]]; thencolors=${colors//n/}opt='-ne'fiif [[ $colors =~ "," ]]; thencolorarr=${colors//,/ }colors=${colors//,/;}for color in ${colorarr[@]};doif ! [[ $color =~ ^[0-9]+$ && $color -gt 0 && $color -lt 49 ]]; thenrightpattern='false'fidoneelseif ! [[ $colors =~ ^[0-9]+$ && $colors -gt 0 && $colors -lt 49 ]]; thenrightpattern='false'fifiif [[ -n $input && $rightpattern = 'true' ]]; thenshift && str="$@"echo $opt "\033[${colors}m${str}\033[0m"elsestr="$@"echo $opt "${str}"fifi
}log $@

使用

  • 输出i-提示、w-告警、s-成功和e-错误信息
sh log.sh i wlf is a coder
sh log.sh w wlf is a coder
sh log.sh s wlf is a coder
sh log.sh e wlf is a coder

在这里插入图片描述

  • 直接输出字符串,和echo功能一样
sh log.sh wlf is a coder
sh log.sh 'wlf is a coder'

在这里插入图片描述

  • 输入参数第一个字符为n则不换行输出,相当于echo -n
sh log.sh nwlf is a coder

在这里插入图片描述

  • 输入字体设置序号设置输出字体
sh log.sh 33 wlf is a coder
sh log.sh n33 wlf is a coder
sh log.sh 333 wlf is a coder

在这里插入图片描述

  • 多种格式英文分号,分隔
sh log.sh 4,33 wlf is a coder
sh log.sh n4,33 wlf is a coder
sh log.sh 4,333 wlf is a coder

在这里插入图片描述

字体设置表

序号设置
0重新设置属性到缺省设置
1设置粗体
2设置一半亮度(模拟彩色显示器的颜色)
4设置下划线(模拟彩色显示器的颜色)
5设置闪烁
7设置反向图象
22设置一般密度
24关闭下划线
25关闭闪烁
27关闭反向图象
30设置黑色前景
31设置红色前景
32设置绿色前景
33设置棕色前景
34设置蓝色前景
35设置紫色前景
36设置青色前景
37设置白色前景
38在缺省的前景颜色上设置下划线
39在缺省的前景颜色上关闭下划线
40设置黑色背景
41设置红色背景
42设置绿色背景
43设置棕色背景
44设置蓝色背景
45设置紫色背景
46设置青色背景
47设置白色背景
49设置缺省黑色背景

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/504581.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爬虫入门到精通_实战篇8(分析Ajax请求并抓取今日头条美食美图)_界面上抓取Ajax方式

1 目标 目标: 抓取今日头条美食美图,如下: 一些网页直接请求得到的HTML代码并没有在网页中看到的内容,因为一些信息是通过Ajax加载,并通过js渲染生成的,这时就需要通过分析网页的请求来获取想要爬取的内容…

LeetCode 热题 100 | 图论(二)

目录 1 基础知识 1.1 什么是拓扑排序 1.2 如何进行拓扑排序 1.3 拓扑排序举例 2 207. 课程表 3 210. 课程表 II 菜鸟做题,语言是 C 1 基础知识 1.1 什么是拓扑排序 含义:根据节点之间的依赖关系来生成一个有序的序列。 应用&#xff1a…

智能分析网关V4安全帽检测/反光衣检测/通用工服检测算法及应用

TSINGSEE青犀视频智能分析网关V4内置了近40种AI算法模型,支持对接入的视频图像进行人、车、物、行为等实时检测分析,上报识别结果,并能进行语音告警播放。硬件管理平台支持RTSP、GB28181协议、以及厂家私有协议接入,可兼容市面上常…

Redux 简介

一 Redux 应用场景 随着JavaScript单页应用开发日趋复杂,管理不断变化的state 非常困难 Redux 的出现就是为了解决state里的数据问题 在React中,数据在组件中是单向流动的 数据从一个方向父组件流向子组件(通过props),由于这个特…

【python开发】网络编程(上)

这里写目录标题 一、必备基础(一)网络架构1、交换机2、路由器3、三层交换机4、小型企业基础网络架构5、家庭网络架构6、互联网 (二)网络核心词汇1、子网掩码和IP2、DHCP3、内网和公网IP4、云服务器5、端口6、域名 一、必备基础 &…

CCF推荐会议|截稿倒计时 计算机图形学与多媒体领域3-4月份截稿资讯!

会议之眼精心汇总了以下CCF推荐会议之计算机十大领域之一:计算机图形学与多媒体领域!2024年度3-4月份会议截稿日期将近!会议之眼致力于为科研学者第一时间获取最新学术资讯!助力广大学者保持领先优势!愿科研人员们在专…

Home Assistant:基于Python的智能家居开源系统详解

Home Assistant:基于Python的智能家居开源系统详解 在数字化和智能化的时代,智能家居系统成为了现代家庭的新宠。它们能够让我们更加方便地控制家中的各种设备,实现自动化和个性化的居住体验。其中,Home Assistant作为一款基于Pyt…

正规的相亲交友软件哪个好?分享目前最可靠的5款相亲APP软件

随着中国单身人数的不断增加,相亲 APP 平台的市场需求增大,相亲 APP 平台的数量也越来越多,下面为你盘点当下热门的五大相亲软件: NO1:丛丛 这是我用的最久的一款脱单交友小程序,我老公就是在这个小程序找到…

【go语言开发】swagger安装和使用

本文主要介绍go-swagger的安装和使用,首先介绍如何安装swagger,测试是否成功;然后列出常用的注释和给出使用例子;最后生成接口文档,并在浏览器上测试 文章目录 安装注释说明常用注释参考例子 文档生成格式化文档生成do…

Qt 简约又简单的加载动画 第七季 音量柱风格

今天和大家分享两个音量柱风格的加载动画,这次的加载动画的最大特点就是简单,只有几行代码. 效果如下: 一共三个文件,可以直接编译运行 //main.cpp #include "LoadingAnimWidget.h" #include <QApplication> #include <QGridLayout> int main(int argc…

DSI2协议之BTA行为理解

概念: DSI协议spec支持总线控制权在master和slave之间发生交换,即通过bus turn around来实现; BUS TURN AROUND: BTA 的实现是通过controller—>cdphy的turnrequest信号来实现; 关于控制器发出turnrequest给phy,phy通过lvds/trio线输出turnaround sequence如下图中…