偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Linux命令行知識(shí)深似海

系統(tǒng) Linux
如果你有一個(gè)4.2GB的CSV文件,里面有超過(guò)1200萬(wàn)條記錄,每條記錄都有50列。現(xiàn)在你要做的是把其中某一列的值全加起來(lái)。你怎么辦?對(duì)于一個(gè)Linux/unix命令行高手來(lái)說(shuō),這真是小菜一碟。

如果你有一個(gè)4.2GB的CSV文件,里面有超過(guò)1200萬(wàn)條記錄,每條記錄都有50列?,F(xiàn)在你要做的是把其中某一列的值全加起來(lái)。你怎么辦?

這是我最近看到的一篇文章的開(kāi)頭部分。文章介紹的是如何使用unix命令來(lái)分析大體積文件的文章。像我這樣一個(gè)基本上都在Windows平臺(tái)上開(kāi)發(fā)的程序員,對(duì)他提出的這樣一個(gè)問(wèn)題,首先出現(xiàn)在腦子里的就是內(nèi)存溢出、CPU達(dá)到100%、跑一個(gè)晚上。而對(duì)于一個(gè)Linux/unix高手來(lái)說(shuō),這真是小菜一碟,正如文章中介紹的方法,一行命令就完成了這個(gè)任務(wù)。

(假設(shè)文件名叫做data.csv,行數(shù)據(jù)用豎線分割,我們需要總計(jì)其中的第四列。)

 cat data.csv | awk -F “|” ‘{ sum += $4 } END { printf “%.2f\n”, sum }’

簡(jiǎn)潔干凈,而且里面的{ sum += $4 }很有閉包的味道。讓我對(duì)Linux的向往又加深了一層。

我寫(xiě)這篇博客的目的并不是抒發(fā)對(duì)Linux的感情的,而是重點(diǎn)講一下發(fā)生在這篇文章評(píng)論里的事情。這篇文章吸引了不少Linux愛(ài)好者的評(píng)論,而且都是Liunx高手,僅僅是第一條評(píng)論,看了后就讓我驚訝的合不上嘴。

這位叫做California Lotto的網(wǎng)名的評(píng)論是:

如果你認(rèn)為自己是一個(gè)Linux命令行高手,那恭喜你贏得今天的“最沒(méi)用的Cat用法”大獎(jiǎng)。你應(yīng)該這樣寫(xiě)這個(gè)命令:

awk -F "|" '{ sum += $4 } END { printf "%.2f\n", sum }' < data.csv

的確,cat在這里似乎是沒(méi)必要的。我首先是佩服,可之后馬上感覺(jué)這個(gè)人可真討厭,賣弄。雖然我不喜歡他無(wú)視作者寫(xiě)這片好博文的辛苦,但作為外行人,他和作者一樣都是我高不可及的。

可是當(dāng)我讀第二條評(píng)論時(shí),事情出現(xiàn)了戲劇性的變化,這第二條評(píng)論明顯是真對(duì)第一條評(píng)論的:

如果你認(rèn)為自己是一個(gè)Linux命令行高手,那恭喜你贏得今天的“最沒(méi)用的重定向用法”獎(jiǎng)。你應(yīng)該這樣寫(xiě)這個(gè)命令:

awk -F "|" '{ sum += $4 } END { printf "%.2f\n", sum }' data.csv

正所謂強(qiáng)中自有強(qiáng)中手,一山更比一山高。我突然意識(shí)到,其實(shí)沒(méi)必要在這里比誰(shuí)比誰(shuí)更強(qiáng),在這個(gè)浩瀚的互聯(lián)網(wǎng)里,永遠(yuǎn)都會(huì)有比你在某方法更出眾的人。這里重要的是探討和參與。通過(guò)這種探討,不僅豐富了你我的知識(shí),而且對(duì)問(wèn)題的解決方案有了更豐富的認(rèn)識(shí)。正像接下來(lái)的評(píng)論里繼續(xù)指出,命令行這的重定向符放在什么地方都可以,寫(xiě)成這樣也是好用的:

 <data.csv awk -F “|” ‘{ sum += $4 } END { printf “%.2f\n”, sum }’

神奇吧!而接下來(lái)繼續(xù)有人指出,作者在實(shí)驗(yàn)時(shí)寫(xiě)成這樣:

 head -1 data.psv | awk -F’|’ ‘{print NF}’

實(shí)驗(yàn)成功后直接把head改成cat是順理成章的事。

不管怎樣,這是一篇好文章,這些人都是高手,都是我的老師,不僅教我編程知識(shí),更教我如何做人。

責(zé)任編輯:黃丹 來(lái)源: 外刊IT評(píng)論
相關(guān)推薦

2009-12-24 14:51:39

Linux命令行

2010-09-01 14:23:54

Linux命令行開(kāi)發(fā)

2009-12-09 09:25:52

Linux命令行svn命令

2025-08-05 07:52:41

man 命令Linux命令行

2009-12-23 14:14:09

Linux高級(jí)命令行

2010-09-03 09:18:23

LinuxUNIX命令行

2014-01-24 09:09:32

Linux命令行網(wǎng)速

2018-04-23 08:45:05

Linux命令行

2010-06-01 19:14:53

SVN命令行

2011-08-22 11:51:13

Linuxconfigure

2018-07-10 14:29:05

Linux命令行

2018-02-10 17:30:41

Linux命令

2017-08-29 15:15:40

Linux命令公網(wǎng)IP

2011-07-11 13:20:13

linuxuniq

2010-04-09 16:36:54

Unix操作系統(tǒng)

2010-04-20 11:16:08

Unix操作系統(tǒng)

2009-08-11 09:58:22

Linux命令行Linux命令svn命令

2018-09-04 10:39:40

開(kāi)發(fā)

2009-12-25 17:05:09

LINUX Bash

2017-09-05 08:57:02

Linux命令行技巧
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)