質問

私プの最長長さのラインでファイルです。理想的にはこの簡単なbashシェルコマンドの代わりに記述します。

役に立ちましたか?

解決

WC(GNUのcoreutilsの)7.4を使用した:

wc -L filename

与えます:

101 filename

他のヒント

awk '{print length, $0}' Input_file |sort -nr|head -1

参考:ファイルの中で最も長い行を検索する。

awk '{ if (length($0) > max) {max = length($0); maxline = $0} } END { print maxline }'  YOURFILE 

楽しい教育の目的 純粋なPOSIXシェル溶液, なく、無駄な使用して、国や国際機関な分岐に外部コマンド.かファイル名として最初の引数:

#!/bin/sh

MAX=0 IFS=
while read -r line; do
  if [ ${#line} -gt $MAX ]; then MAX=${#line}; fi
done < "$1"
printf "$MAX\n"
wc -L < filename

与えます。

101
perl -ne 'print length()."  line $.  $_"' myfile | sort -nr | head -n 1

は、長さ、行番号を印刷し、そして最長の行の内容

perl -ne 'print length()."  line $.  $_"' myfile | sort -n

行番号および長さと、すべての行のソートされたリストを印刷

.は連結演算子である - それは長さの後に、ここで使用される()
$.は、現在の行番号です
$_が現在の行です。

重要なのは、上記の例のポイントを見落としています。

以下の2例は、タブを展開数

  wc -L  <"${SourceFile}" 
# or
  expand --tabs=1 "${SourceFile}" | awk '{ if (length($0) > max) {max = length($0)} } END { print max }'

以下の2カウントが非タブをexpanedます。

  expand --tabs=1 "${SourceFile}" | wc -L 
# or
  awk '{ if (length($0) > max) {max = length($0)} } END { print max }' "${SourceFile}"

これ

              Expanded    nonexpanded
$'nn\tnn'       10            5

最も長い行の行番号を与えていないすべての回答を検索します。コマンドに続いて行番号とおおよその長さを与えることができます:

$ cat -n test.txt | awk '{print "longest_line_number: " $1 " length_with_line_number: " length}' | sort -k4 -nr | head -3
longest_line_number: 3 length_with_line_number: 13
longest_line_number: 4 length_with_line_number: 12
longest_line_number: 2 length_with_line_number: 11

Perlでます:

perl -ne 'print ($l = $_) if (length > length($l));' filename | tail -1

これはだけでなく、その長すぎます。

、行を出力します

ここでanwserの参照です。

cat filename | awk '{print length, $0}'|sort -nr|head -1

http://wtanaka.com/node/7719する

楽しみのためだけに、ここでPowerShellのバージョンがあります:

cat filename.txt | sort length | select -last 1

そして、ちょうど長さを取得するには:

(cat filename.txt | sort length | select -last 1).Length

私は、Unix環境で、仕事gzippedファイル数一般財政支援です。いたしまし以下のコマンドを2GB gzippedファイル記録の長さ2052.

  1. zcat <gzipped file> | wc -L

  1. zcat <gzipped file> | awk '{print length}' | sort -u

の時間に平均

  1. 117秒

  2. 109秒

ここでは、私のスクリプトから約10運行しています。

START=$(date +%s) ## time of start

zcat $1 |  wc -L

END=$(date +%s) ## time of end
DIFF=$(( $END - $START ))
echo "It took $DIFF seconds"

START=$(date +%s) ## time of start

zcat $1 |  awk '{print length}' | sort -u

END=$(date +%s) ## time of end
DIFF=$(( $END - $START ))
echo "It took $DIFF seconds"

をテーマにバリエーションます。

この1は、彼らがソースに表示される順序を保持、ファイル内で見つかった最も長い行の長さを持つのすべてのの行が表示されます。

FILE=myfile grep `tr -c "\n" "." < $FILE | sort | tail -1` $FILE

だから、myfileの

x
mn
xyz
123
abc

タグ与えます
xyz
123
abc
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top