awkg is an awk-like text-processing tool powered by python language
Project description
awkg
awkg
is a awk
like utility using modern day python language.
awk
is amazingly simple, fast and quite handy. However, its domain specific constrain
sometimes get in our way.
awkg
follows the steps of awk
's design (including its convention for name😉)
and exposes full power of the modern day python.
Python's large set of off-the-shelf existing libraries can of course be imported and used.
Installation
# Install from github
$ pip install git+https://github.com/thammegowda/awkg.git
# Install from pypy coming soon
# pip install awkg
CLI usage:
$ awkg -h
usage: awkg [-h] [-i INP] [-o OUT] [-F FS] [-OFS OFS] [-ORS ORS]
[-b BEGIN_SCRIPT] [-e END_SCRIPT] [-im IMPORTS] [-it INIT_PATH]
[-v]
inline_script
awkg is an awk-like text-processing tool powered by python language
positional arguments:
inline_script Inline python script
optional arguments:
-h, --help show this help message and exit
-i INP, --inp INP Input file path; None=STDIN
-o OUT, --out OUT Output file path; None=STDOUT
-F FS, -FS FS, --field-sep FS
the input field separator. Default=None implies white
space
-OFS OFS, --out-field-sep OFS
the out field separator. Default=None implies same as
input FS.
-ORS ORS, --out-rec-sep ORS
the output record separator. Default=None implies same
as input RS.
-b BEGIN_SCRIPT, --begin BEGIN_SCRIPT
BEGIN block. initialize variables or whatever
-e END_SCRIPT, --end END_SCRIPT
END block. Print summaries or whatever
-im IMPORTS, --import IMPORTS
Imports block. Specify a list of module names to be
imported.Semicolon (;) is the delimiter. Ex:
json;numpy as np
-it INIT_PATH, --init INIT_PATH
The rc file that initializes environment.Default is
$HOME/.awkg.py
-v, --version show program's version number and exit
Example
Compute mean and std of words per sequence
cat data/train.src | awkg -b 'arr=[]; import numpy as np' 'arr.append(NF)' \
-e 'arr=np.array(arr); print(f"{NR} lines from {FNAME}, mean={arr.mean():.2f}; std={arr.std():.4f}")'
Filter records
# use print() explicitely
cat data/train.src | awkg 'if NF >= 25: print(*R)'
Assign boolean expression to special variable RET to trigger implicit print
cat data/train.src | awkg 'RET = NF >= 25'
# print respects the OFS value
cat data/train.src | awkg 'if NF >= 25: print(NR, NF)' -OFS='\t'
Special Variables
NF
: Number of fieldsNR
: Record numberR
: An array having all the columns of current record.R0
: analogous to$0
it stores the input line before splitting intoR
; since python does not permit$
in the identifiers, it is renamed asR0
RET
: When this variable is set to Truth value oftrue
implicitprint(*R)
is triggeredFS
: Input Field separatorOFS
: Output Field separator; Unless explicitly set,OFS=FS
ORS
: Output Record separatorRS
(Currently Not in use)_locals
,_globals
- all variables in local and global scope
You are allowed to use any valid python identifiers, than the above variables
Author:
Related tools
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
awkg-0.1.2.tar.gz
(5.4 kB
view details)
Built Distribution
awkg-0.1.2-py3-none-any.whl
(6.1 kB
view details)
File details
Details for the file awkg-0.1.2.tar.gz
.
File metadata
- Download URL: awkg-0.1.2.tar.gz
- Upload date:
- Size: 5.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.23.4 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ee35c573afd0a51070c1525b432176f58da2fd31e766c31c876f9b937ee41975 |
|
MD5 | fbeed47c4c06dc385c3be1f1da4c6298 |
|
BLAKE2b-256 | 99dceff19be8149caa36a50496618995617318e243ffab82c9da0e4682ac65b1 |
File details
Details for the file awkg-0.1.2-py3-none-any.whl
.
File metadata
- Download URL: awkg-0.1.2-py3-none-any.whl
- Upload date:
- Size: 6.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.23.4 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d47c730d50a4f00cb4f73dadba21feffad4de4a406fe5bd13027b7555670a8dd |
|
MD5 | daf769a5947137d200a5ad7056a00e4a |
|
BLAKE2b-256 | 2a33567af991d27f607b6a3a83b97bb24f2aeeb25a6f24650d020a57525085d8 |