Linux Shell編程 awk

来源:http://www.cnblogs.com/jhc888007/archive/2017/06/17/7041637.html
-Advertisement-
Play Games

awk [-field-separator] 'commands' input-file(s) ...


  • awk [-field-separator] 'commands' input-file(s)

基本模式

  • awk -F':' ... 

使用#分隔

  • awk '{print $0}' a.txt 

列印全部

  • awk '{print $1,$3}' a.txt 

列印第1、3列

  • awk 'BEGIN{print "0"}{print $1}' a.txt  

第一行列印0

  • awk '{print $1}END{print "0"}' a.txt 

最後一行列印0

  • awk '$1 == "0" {print $0}' a.txt 

第一列等於0的行

  • awk '$1!="0" {print $0}' a.txt 

第一列不等於0的行

  • awk '$1<=$2' 

第一列小於等於第二列的行

  • awk '$0!~/0/' a.txt 

正則匹配所有列不含0的行

  • awk '$1~/(12|(34)/' a.txt 

正則匹配第一列匹配12或34的行

  • awk 'if($1>1 && $2<1) {print $1} a.txt 

第一列大於1且第二列小於1的行的第一列

  • awk 'if($1>1 || $2<1) {print $2} a.txt 

第一列大於1或第二列小於1的行的第二列

  • awk '{print NF RS NR}' a.txt 

連續列印記錄列數、記錄分隔符、已讀記錄數

  • awk 'NR==FNR {print $1} NR>FNR {print $2}' a.txt b.txt 

列印第一個文件的第一列和第二個文件的第二列

  • awk '{$1=$1*2; print $1}' a.txt

修改數值列印

  • awk 'BEGIN{LAST=0} {if($1>LAST) print $1; LAST=$1}'

逐個比較列印遞增數列

  • awk '{total+=$1} END {print total}' a.txt

統計列值

  • awk '{printf "%c", $1}' a.txt

格式化輸出

  • awk '{print match($1, "1")}' a.txt

列印第一列第一個1的位置,沒有列印0

  • awk '{gsub(/ab/,"cd",$1); print $0}' a.txt

第一列字元串替換

  • awk '{MAP[$1]=$2} END {for(I in MAP){print I, MAP[I]} }' a.txt

字典存儲和提取


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • could not start the service MySQL .error 0 安裝時無法啟動服務 在MySQL資料庫卸載後重裝時,一定要將MySQL的相關服務,文件夾,註冊表刪除徹底 1.打開service.msc關閉MySQL服務 2.控制面板 -> 程式和功能 -> MYSQL 雙擊卸載 ...
  • 我們以Oracle自帶的表來做例子 主要兩張表:dept、emp 一個是部門,一個是員工表結構如下: emp name null? Type Empno not null number(4) ename varchar2(10) job varchar2(9) mgr number(4) hired ...
  • MySQL授權命令grant的使用方法:grant 許可權 on 資料庫對象 to 用戶 ...
  • 我們使用資料庫的時候,如果查詢條件太複雜,則會涉及到很多問題 1、無法維護,各種嵌套查詢,各種複雜的查詢,想要優化都無從下手 2、效率低下,一般語句複雜了之後,比如使用or,like %,,%查詢之後資料庫的索引就沒有辦法利用到了,這個時候的搜索就會全表掃描,數據量少的時候可能性能還能接受,但是數據 ...
  • 1.安裝好jdk。 2.打開終端。 3.sudo到root帳戶,輸入 vi /etc/profile ,打開全局配置文件。 4.在profile中添加如下配置 JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_40.jdk/Contents/ ...
  • 在編程或是整理知識的時候一直苦於沒有一款可以幫助理清思路的工具。 在網上苦尋良久,終於找到了一款可心可意的小軟體 —— Graphviz。 折騰了一番,終於可以湊合著用了。 現將折騰的成果記錄於此以作備忘,當然如果能夠拋磚引玉那就再好不過了。 因為本人主要使用 Windows 以下將用 Window ...
  • ubuntn預設下載路徑的源是國外的下載很慢換成國內的下載路徑會好很多 在ubuntu應用搜索框(左上腳那個)中輸入software 1.software&Updates 應用點擊software 2.在彈出的界面中的download中選擇other 3.在之後彈出的框中選到china 4.在裡面選 ...
  • Shell腳本,就是利用Shell的命令解釋的功能,對一個純文本的文件進行解析,然後執行這些功能,也可以說Shell腳本就是一系列命令的集合。Shell可以直接使用在win/Unix/Linux上面,並且可以調用大量系統內部的功能來解釋執行程式,如果熟練掌握Shell腳本,可以讓我們操作電腦變得更 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...