forked from HariSekhon/DevOps-Bash-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsplit.sh
executable file
·88 lines (72 loc) · 1.99 KB
/
split.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#!/usr/bin/env bash
# vim:ts=4:sts=4:sw=4:et
#
# Author: Hari Sekhon
# Date: 2019-03-05 18:18:13 +0000 (Tue, 05 Mar 2019)
#
# https://github.com/harisekhon/bash-tools
#
# License: see accompanying Hari Sekhon LICENSE file
#
# If you're using my code you're welcome to connect with me on LinkedIn and optionally send me feedback to help steer this or other code I publish
#
# https://www.linkedin.com/in/harisekhon
#
set -euo pipefail
[ -n "${DEBUG:-}" ] && set -x
srcdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
# shellcheck disable=SC1090
. "$srcdir/lib/utils.sh"
usage(){
if [ -n "$*" ]; then
echo "$@"
echo
fi
cat <<EOF
Splits big file(s) in to \$PARTS parts (defaults to the number of CPU cores)
Useful for easy parallelizing things that don't easily lend themselves to parallelization like
anonymize.py from DevOps Python Tools which needs successive ordered anonymization rules
usage: ${0##*/} <files>
-p --parts Number of parts to split files in to (\$PARTS, defaults to number of CPU cores)
-h --help Show usage and exit
EOF
exit 3
}
if [ $# -eq 0 ]; then
usage "no file arguments given"
fi
for x in "$@"; do
case "$x" in
-h|--help) usage
;;
esac
done
check_bin split
check_bin parallel
parts="${PARTS:-}"
if [ -z "$parts" ]; then
parts="$(cpu_count)"
fi
file_list=""
while [ $# -gt 0 ]; do
case $1 in
-p|--parts) parts="$2"
shift
;;
-h|--help|-*) usage
;;
*) file_list="$file_list $1"
;;
esac
shift
done
for filename in $file_list; do
echo "Splitting $filename in to $parts parts"
if [ "$(uname -s)" = "Darwin" ]; then
linecount="$(wc -l < "$filename" | awk '{print $1}')"
parts="$(bc <<< "$linecount / $parts")"
split -l "$parts" "$filename" "$filename."
else
split -d -n "l/$parts" "$filename" "$filename."
fi
done