Ad Hoc Data Analysis From The Unix Command Line/Appendices

From Wikibooks, open books for an open world
Jump to navigation Jump to search

Appendix A: pcalc source code[edit]

A perl read-eval-print loop. This makes a very handy calculator on the command line. Example usage:

$ pcalc 1+2
$ pcalc "2*2"
$ pcalc 2*3


use strict;
if ($#ARGV >= 0) {
  eval_print(join(" ",@ARGV))
} else { 
  use Term::ReadLine;
  my $term = new Term::ReadLine 'pcalc';
  while ( defined ($_ = $term->readline("")) ) {
    $term->addhistory($_) if /\S/;

sub eval_print {
  my ($str) = @_;
  my $result = eval $str;
  if (!defined($result)) {
    print "Error evaluating '$str'\n";
  } else {
    print $result,"\n";

Appendix B: Random unfinished ideas[edit]

Ideas too good to delete, but that aren't fleshed out.

Micro shell scripts from the command line[edit]

Example - which .so has the object I want?

Using backticks[edit]

Example - killing processes by name[edit]

kill `ps auxww | grep httpd | grep -v grep | awk '{print $2}'`

Example - tailing the most recent log file in one easy step[edit]

tail -f `ls -rt *log | tail -1`

James' xargs trick[edit]

James uses echo with xargs and feeds one xargs' output into another xargs in clever ways to build up complex command lines.


perl + $/ == agrep[edit]

Example - Finding duplicate keys in two files[edit]

Quick Plotting With gnuplot