源:

218.104.69.100                    218.104.69.100                    安徽合肥
218.104.69.99 218.104.69.99 安徽合肥
61.190.72.38 61.190.72.38 安徽合肥
61.190.75.3 61.190.75.3 安徽合肥
61.190.75.6 61.10.75.6 安徽合肥
166.111.172.198 166.111.172.198 北京
166.111.172.199 166.111.173.25 北京
1.8.3.3 3.3.3.3 江苏南京
210.28.128.0 210.28.129.255 江苏南京
23.23.23.23 33.33.33.33 江苏南京
3.3.3.3 2.2.2.33 江苏南京
3.3.3.3 2.2.22.33 江苏南京
3.3.3.3 2.33.22.33 江苏南京
3.3.3.3 22.33.22.33 江苏南京 我想把它变成: 218.104.69.100 :218.104.69.100 :安徽合肥
218.104.69.99 :218.104.69.99 :安徽合肥
61.190.72.38 :61.190.72.38 :安徽合肥
61.190.75.3 :61.190.75.3 :安徽合肥
61.190.75.6 :61.10.75.6 :安徽合肥
166.111.172.198:166.111.172.198:北京
166.111.172.199:166.111.173.25 :北京
1.8.3.3 :3.3.3.3 :江苏南京
210.28.128.0 :210.28.129.255 :江苏南京
23.23.23.23 :33.33.33.33 :江苏南京
3.3.3.3 :2.2.2.33 :江苏南京
3.3.3.3 :2.2.22.33 :江苏南京
3.3.3.3 :2.33.22.33 :江苏南京
3.3.3.3 :22.33.22.33 :江苏南京 说明:
1、不要管中文汉字的第三列有多少个字符串(可能很多个)
2、只管前两列上面字符串最小的3.3.3.3 最大的166.111.172.198 (只是举例,明白意思就行了)
3、前两列最大的字符串后面紧跟冒号,其余达不到最大字符串数量的加空格填充

我的想法是,先遍历第一列和第二列,取出两列各自字符串的最大长度,然后格式化最大长度的宽度即可。

[root]$ cat replacespace  | awk -v i= 'BEGIG{maxlen=0;maxlen2=0;i=0}{if(maxlen<length($1)){maxlen=length($1)};if(maxlen2<length($2)){maxlen2=length($2)};arr1[i]=$1;arr2[i]=$2;arr3[i]=$3;i++} END{for(j=0;j<i;j++) {printf("%-"maxlen"s%s%-"maxlen2"s%s%s\n",arr1[j],":",arr2[j],":",arr3[j])} }'
218.104.69.100 :218.104.69.100 :安徽合肥
218.104.69.99 :218.104.69.99 :安徽合肥
61.190.72.38 :61.190.72.38 :安徽合肥
61.190.75.3 :61.190.75.3 :安徽合肥
61.190.75.6 :61.10.75.6 :安徽合肥
166.111.172.198:166.111.172.198:北京
166.111.172.199:166.111.173.25 :北京
1.8.3.3 :3.3.3.3 :江苏南京
210.28.128.0 :210.28.129.255 :江苏南京
23.23.23.23 :33.33.33.33 :江苏南京
3.3.3.3 :2.2.2.33 :江苏南京
3.3.3.3 :2.2.22.33 :江苏南京
3.3.3.3 :2.33.22.33 :江苏南京
3.3.3.3 :22.33.22.33 :江苏南京

【shell】awk格式对齐文本的更多相关文章

  1. Shell awk文本处理,shell脚本编写

    Shell awk文本处理,shell脚本编写 一:内容包含awk.变量.运算符.if多分支 <a>语法糖: awk [options] 'commands' files option - ...

  2. 转 shell awk 使用详解

    awk简介 awk: 中文意思是报告生成器 能够根据我们输入的信息,将信息格式化以后显示,将定义好的信息以比较美观(直观)的方式显示出来出现比较早,继而出现了new awk(nawk)在windows ...

  3. [转]shell awk 入门,中级,高级使用

    awk很常用,对于我们在shell中分析log和file很有好处,很实用的东西,大家一起分享学习- 作为技术支持工程师,我们最最经常的工作就是要处理文本文件,不管是什么数据库最后都可以导成文本,我们就 ...

  4. 使用awk格式化输出文本

    注意:本文并不是一篇awk入门文章,而是偏重实例讲解 awk借鉴了c语法,因此awk在许多地方还保留有c语言的痕迹,比如printf语句:for,if的语法结构等 介绍 最简单地说,AWK 是一种用于 ...

  5. Linux Shell 自动化之让文本飞

    Linux Shell 自动化之让文本飞 一.前言: ​ 作者之前在一家 IDC 从事运维兼职工作,后来因某些原因辞职开始 Python 爬虫数据分析.因为这些经历以及后续时间积累下的经验,发现好像自 ...

  6. [19/06/06-星期四] HTML基础_文本标签、列表(有序、无序、定义)、文本格式化(单位、字体、大小写、文本修饰、间距、对齐文本)

    一.文本标签 em:用来表示一段内容的着重点,语气上的强调.一般显示为斜体 i:是斜体显示,和em显示效果一样.h5规定不需要着重的内容而是单纯加粗或斜体可以用i或b.用的不多 strong:用来表示 ...

  7. shell awk

    #!/bin/bash # ;i<=;i++)); # do # c1=`shuf -i - -n ` #生成随机数 # c2=`shuf -i - -n ` # c3=`shuf -i - - ...

  8. python string 对齐文本的几个方法

    用rjust().ljust()和center()方法对齐文本

  9. POI对EXCEL的操作【重点:如何设置CELL格式为文本格式】

    实际开发过程中通常用到的就是从数据库导出EXCEL表格了,JXL可以这样做,其实POI也可以(关于JXL与POI的异同可访问我之前总结的文章),之前写过POI对七种文档(当然也包括EXCEL)的内容读 ...

随机推荐

  1. mac打开已损坏或者不明来源的应用的解决方法

    如遇:「xxx.app已损坏,打不开.你应该将它移到废纸篓」,并非你安装的软件已损坏,而是Mac系统的安全设置问题,因为这些应用都是破解或者汉化的,那么解决方法就是临时改变Mac系统安全设置.出现这个 ...

  2. 【HANA系列】SAP 【第一篇】EXCEL连接SAP HANA的方法(ODBC)

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP [第一篇]EXCEL连接 ...

  3. CSRF-DVWA_1.9-笔记

     CSRF : Cross-site request forgery  跨站请求伪造   所用到的工具: Firefox浏览器及其插件     HackBar(快速构造URL)     和     T ...

  4. 快速乘+快速幂(用于模数超过int范围)

    一般的快速幂并不适合模数大于int范围的情况,因为在乘法运算的过程可能会出现超出long long的情况出现.这个时候可以利用快速幂的思想使用快速乘,原理就是模拟乘法运算,将乘法运算分解成加法运算,再 ...

  5. [转帖]教你如何修改运行中的docker容器的端口映射

    教你如何修改运行中的docker容器的端口映射   在docker run创建并运行容器的时候,可以通过-p指定端口映射规则.但是,我们经常会遇到刚开始忘记设置端口映射或者设置错了需要修改.当dock ...

  6. 开发维护中遇到问题---eclipse、发版问题

    1.jar包冲突问题, [服务器启动service服务器,tomcat也已启动]然后浏览器访问,会出现这样子的问题现象:tomcat什么的启动成功,但是访问时会出现404: 解决方法:先停掉tomca ...

  7. 【洛谷p1058】立体图(已完结)

    立体图[题目链接] 然后因为有点(不是有点,非常)懵,因此我只能看一步写一步. 首先总体思路: 将三维立体图看做二维平面图,先确定出二维图的长和宽,然后,按照三维立体图的透视顺序,从最后一排的最左开始 ...

  8. 2017.10.21 C组比赛总结

    今天考得不太好,只拿了100+0+0+30=130分... [GDKOI训练]音乐节拍 考场AC了! 其实就是大水一道! 思路:二分查找 每次输入后,输出该时刻所在的区间的编号就好了. 总体难度:★★ ...

  9. Spark RDD理解-总结

    1.spark是什么 快速.通用.可扩展的分布式计算引擎. 2. 弹性分布式数据集RDD RDD(Resilient Distributed Dataset),是Spark中最基本的数据抽象结构,表示 ...

  10. PostgreSQL-事务与commit优化

    基本概念 事务 Transaction 是 数据库管理系统DBMS 执行过程中的一个逻辑单元,是一个 sql命令组成的序列. 其特点在于,当事务被提交DBMS后,DBMS需要确保所有的操作被完成:如果 ...