How to utilize it? See examples.
- Enumeration of various patterns from the standard input.
- Useful equivalents for existent Linux commands (inspired by nixar).
- Controlling records and fields given by particular separator (inspired by Open-Usp-Tukubai).
egzact requires Egison version 4.1.2. Following installation procedure include installation of Egison.
$ sudo yum install https://git.io/egison-4.1.2.x86_64.rpm ## Install Egison
$ sudo yum install https://git.io/egzact-2.1.1.rpm ## Install egzact
$ wget https://git.io/egison-4.1.2.x86_64.deb
$ sudo dpkg -i egison-4.1.2.x86_64.deb ## Install Egison
$ wget https://git.io/egzact-2.1.1.deb
$ sudo dpkg -i egzact-2.1.1.deb ## Install egzact
$ brew install egison/egison/egison ## Install Egison
$ brew install greymd/tools/egzact ## Install egzact
Print whole the inputs as multiple rows with given number of cols.
Location of each field is shifted over to the left by comparison with one upper line.
The reason why the name is conv is, the behavior looks like the convolution.
$ seq 10 | conv 2
1 2
2 3
3 4
4 5
5 6
6 7
7 8
8 9
9 10
$ yes | awk '$0=NR' | conv 3 | head
1 2 3
2 3 4
3 4 5
4 5 6
5 6 7
.
.
.
Print whole the inputs as multiple rows with given number of cols. In default, it just removes the new lines.
$ seq 10 | flat
1 2 3 4 5 6 7 8 9 10The behavior is same as xargs -n N option. However Common command line options like fs can be used.
$ seq 10 | flat 2
1 2
3 4
5 6
7 8
9 10
# Comma separeted file
$ cat myfile
AA,AB,AC,AD
BA,BB,BC,BD
CA,CB,CC,CD
DA,DB,DC,DD
# Field separator(fs) option is useful for keeping comma.
$ cat myfile | flat fs=, 8
AA,AB,AC,AD,BA,BB,BC,BD
CA,CB,CC,CD,DA,DB,DC,DDDivide whole the inputs into given number of rows.
# Print A to Z with 3 rows.
$ echo {A..Z} | slit 3
A B C D E F G H I
J K L M N O P Q R
S T U V W X Y Z
# Each line's number of field is adjusted to be near each other as much as possible.
$ echo A B C D | slit 3
A B
C
DGenerate sublist of the fields. Each result matches to the left side of the original input. In most cases, it looks stairs.
$ echo A B C D | stairl
A
A B
A B C
A B C D$ cat myfile2
AA AB AC AD
BA BB BC BD
CA CB CC CD
# The command is executed for each line.
$ cat myfile2 | stairl
AA
AA AB
AA AB AC
AA AB AC AD
BA
BA BB
BA BB BC
BA BB BC BD
CA
CA CB
CA CB CC
CA CB CC CD
# `eos` option is helpful if you want to know where each result is coming from.
$ cat myfile2 | stairl eos=---
AA
AA AB
AA AB AC
AA AB AC AD
---
BA
BA BB
BA BB BC
BA BB BC BD
---
CA
CA CB
CA CB CC
CA CB CC CDGenerate sublist of the fields. Results match to the right side of the original input. In most cases, it looks stairs.
$ echo A B C D | stairr
D
C D
B C D
A B C DGenerate all the sublist of the fields.
$ echo A B C D | sublist
A
A B
B
A B C
B C
C
A B C D
B C D
C D
DWhole the results is same as stairl | stairr when the duplicated lines can be merged.
$ echo A B C D | stairl | stairr | sort | uniq
A
A B
A B C
A B C D
B
B C
B C D
C
C D
D
$ echo A B C D | sublist | sort | uniq
A
A B
A B C
A B C D
B
B C
B C D
C
C D
DGenerate all the subsets of the fields.
$ echo A B C D | subset
A
B
C
D
A B
A C
B C
A D
B D
C D
A B C
A B D
A C D
B C D
A B C DCrop all the patterns which matches given string (regular expression). It includes all the patterns (from shortest to longest match).
$ echo 1110100110 | crops "1.*1"
11
111
11101
1101
101
11101001
1101001
101001
1001
111010011
11010011
1010011
10011If you want to use normal grep command for matching query, stairr fs="" | stairl fs="" can works with almost same behavior. In addition, it is faster than crops because it works with multi processing.
$ echo 1110100110 | stairr fs="" | stairl fs="" | grep -o '1.*1' | sort | uniq
1001
10011
101
101001
1010011
11
1101
1101001
11010011
111
11101
11101001
111010011Generate all the circulated patterns.
$ echo A B C D E | cycle
A B C D E
B C D E A
C D E A B
D E A B C
E A B C DGenerate combinations of N of fields.
$ echo A B C D | comb 2
A B
A C
B C
A D
B D
C D
Generate permutations of N of fields.
$ echo A B C D | perm 2
A B
A C
B A
A D
B C
C A
B D
C B
D A
C D
D B
D CDuplicate lines.
$ echo A B C D | dupl 3
A B C D
A B C D
A B C DShow given line and reversed line.
Obverse and Reverse
$ echo A B C D | obrev
A B C D
D C B AAdd str to left side of the input.
Add + Left
$ echo abc | addl ABC
ABCabcAdd str to right side of the input.
Add + Right
$ echo abc | addr ABC
abcABCReverse the order of the field.
$ echo A B C D | mirror
D C B APrint first N of fields.
Take + Left
$ echo A B C D | takel 3
A B CPrint last N of fields.
Take + Right
$ echo A B C D | taker 3
B C DPrint fields from first one to the one which matches given regular expression.
Take + Left + regeX
$ echo QBY JCG FCM PAG TPX BQG UGB | takelx "^P.*$"
QBY JCG FCM PAGPrint fields from last one to the one which matches given regular expression.
Take + Right + regeX
$ echo QBY JCG FCM PAG TPX BQG UGB | takerx "^P.*$"
PAG TPX BQG UGBRemove first N of fields.
Drop + Left
$ echo QBY JCG FCM PAG TPX BQG UGB | dropl 3
PAG TPX BQG UGBRemove last N of fields.
Drop + Right
$ echo QBY JCG FCM PAG TPX BQG UGB | dropr 3
QBY JCG FCM PAGExtract particular fields which matches given regular expression.
egZact + gREP
$ echo 1 2 3 4 5 6 7 8 9 10 | zrep "1"
1 10Merge duplicated fields.
egZact + uNIQ
$ echo aaa bbb ccc aaa bbb | zniq
aaa bbb cccAdd particular prefix and suffix to each field in accordance with given argument.
* is the placeholder which represents each field.
$ echo aaa bbb ccc | wrap "<p>*</p>"
<p>aaa</p> <p>bbb</p> <p>ccc</p>Nest all the fields with with given argument.
* is the placeholder which represents each field.
First field is the most deeply nested element.
Nest + Left
$ echo aaa bbb ccc | nestl "<p>*</p>"
<p> <p> <p> aaa </p> bbb </p> ccc </p>Nest all the fields with with given argument.
* is the placeholder which represents each field.
Last field is the most deeply nested element.
Nest + Right
$ echo aaa bbb ccc | nestr "<p>*</p>"
<p> aaa <p> bbb <p> ccc </p> </p> </p>Add str to top of the input.
Add + Top
$ echo abc | addt ABC
ABC
abcAdd str to bottom of the input.
Add + Bottom
$ echo abc | addb ABC
abc
ABCField separator.
- Default value is space
. - Format:
fs=STR
Example
$ echo "/usr/local/var/" | stairl fs=/
/usr
/usr/local
/usr/local/var
/usr/local/var/
# In case of empty, each character is regarded as a field.
$ echo "abcdefg" | stairl fs=""
a
ab
abc
abcd
abcde
abcdef
abcdefgInput field separator.
If fs is already set, this option is primarily used.
- Default value is space
. - Format:
ifs=STR
Example
$ cat myfile3
AA,AB,AC,AD
BA,BB,BC,BD
# "," separated input -> " " separated output.
$ cat myfile3 | stairr ifs=","
AD
AC AD
AB AC AD
AA AB AC AD
BD
BC BD
BB BC BD
BA BB BC BDOutput field separator.
If fs is already set, this option is primarily used.
- Default value is space
. - Format:
ofs=STR
Example
$ cat myfile3
AA,AB,AC,AD
BA,BB,BC,BD
# "," separated input -> "_" separated output.
$ cat myfile3 | cycle ifs="," ofs="_"
AA_AB_AC_AD
AB_AC_AD_AA
AC_AD_AA_AB
AD_AA_AB_AC
BA_BB_BC_BD
BB_BC_BD_BA
BC_BD_BA_BB
BD_BA_BB_BC
# "," separated input -> tab separated output.
$ cat myfile3 | dupl ifs="," ofs="\t" 2
AA AB AC AD
AA AB AC AD
BA BB BC BD
BA BB BC BDEnd of record (a.k.a, row).
Result of each line (record) is separated with new line \n in default.
This option changes the string for separating each record.
- Default value is new line
\n. - Format:
eor=STR
Example
$ cat myfile4
AA AB AC AD
BA BB BC BD
$ cat myfile4 | stairl
AA # End of record
AA AB # End of record
AA AB AC # End of record
AA AB AC AD # End of set
BA # End of record
BA BB # End of record
BA BB BC # End of record
BA BB BC BD # End of set
$ cat myfile4 | stairr eor=" @@@ "
AD @@@ AC AD @@@ AB AC AD @@@ AA AB AC AD
BD @@@ BC BD @@@ BB BC BD @@@ BA BB BC BDEnd of set. Set means, all results generated from single line, in this manual.
- Default value is new line
\n. - Format:
eos=STR
Example
$ cat myfile4
AA AB AC AD
BA BB BC BD
$ cat myfile4 | stairl eos="---"
AA
AA AB
AA AB AC
AA AB AC AD
---
BA
BA BB
BA BB BC
BA BB BC BD
$ cat myfile4 | stairl eos="---" eor=" @@@ " ofs=" | "
AA @@@ AA | AB @@@ AA | AB | AC @@@ AA | AB | AC | AD
---
BA @@@ BA | BB @@@ BA | BB | BC @@@ BA | BB | BC | BDA special command line option each is available in flat, conv and slit commands.
The option changes command's behavior to "each line mode".
In default, those commands handle whole the standard input (STDIN).
However with this option, those commands can read each line and print the result.
Example
$ cat myfile4
AA AB AC AD
BA BB BC BD
$ cat myfile4 | flat 3
AA AB AC
AD BA BB
BC BD
$ cat myfile4 | flat each 3
AA AB AC
AD
BA BB BC
BD
$ cat myfile4 | conv each 3 eos="---"
AA AB AC
AB AC AD
---
BA BB BC
BB BC BD$ make uninstallThis software is released under the MIT License. See LICENSE
UnitTest.hs is distributed on egison/egison under the MIT license.
The logo is licensed under a Creative Commons Attribution-NonCommercial 4.0 International License.