ฉันมี greps piped อนุกรม awks และ seds ซึ่งสร้างรายการของตัวเลขหนึ่งในแต่ละบรรทัด บางสิ่งเช่นนี้
1.13
3.59
1.23
ฉันจะไปป์ไลน์นี้กับสิ่งที่จะส่งออกโดยเฉลี่ยสูงสุดและต่ำสุดได้อย่างไร
ฉันมี greps piped อนุกรม awks และ seds ซึ่งสร้างรายการของตัวเลขหนึ่งในแต่ละบรรทัด บางสิ่งเช่นนี้
1.13
3.59
1.23
ฉันจะไปป์ไลน์นี้กับสิ่งที่จะส่งออกโดยเฉลี่ยสูงสุดและต่ำสุดได้อย่างไร
คำตอบ:
blahblahblah | awk '{if(min==""){min=max=$1}; if($1>max) {max=$1}; if($1<min) {min=$1}; total+=$1; count+=1} END {print total/count, max, min}'
awk
ในรูปแบบหรือดังกล่าวแล้วใช้มันเป็น/usr/local/bin/stats
blabla | stats
ฉันพบว่าโปรแกรมนี้มีประโยชน์สำหรับการสร้างสถิติในรายการตัวเลขที่บรรทัดคำสั่ง: http://web.cs.wpi.edu/~claypool/misc/stats/stats.html
นอกจากนี้ยังมี simple-r ซึ่งสามารถทำเกือบทุกอย่างที่ R สามารถทำได้ แต่มีการกดแป้นน้อยกว่า:
https://code.google.com/p/simple-r/
ในการคำนวณค่าเฉลี่ยค่าสูงสุดและค่าต่ำสุดจะต้องพิมพ์หนึ่งรายการ:
r summary file.txt
r summary - < file.txt
cat file.txt | r summary -
ด้วยปลายหมวกถึง @DerfK:
perl -lane '$n=$F[0]; if(not defined $min){$min=$max=$n}; if($n>$max){$max=$n}; if($n<$min){$min=$n}; $total+=$n; $count+=1; END{print $total/$count." $max $min"}'
$F[0]
คือค่าในฟิลด์แรก (0'th) ของแต่ละบรรทัด
หากข้อมูลอินพุตของคุณถูกคั่นด้วยเครื่องหมายจุลภาคให้เพิ่ม-F,
ตัวแก้ไขก่อน-lane