जवाबों:
यहां पहला कमांड आपके द्वारा देखे गए स्वरूपण का अनुकरण करता है vim
। यह प्रत्येक 4 स्तंभों की टैब-STOP (ts) सेटिंग के आधार पर, समान रूप से रिक्त स्थान की समान संख्या के लिए टैब का विस्तार करता है।
printf "ab\tcd\tde\n" |expand -t4
उत्पादन
ab cd de
रखने के लिए टैब के रूप में टैब और टैब स्टॉप हर 4 स्तंभ के लिए सेट पदों, तो आप जिस तरह से बदलना होगा टैब-चार के साथ पर्यावरण काम करता है (vim के साथ करता है बस के रूप में :set ts=4
आदेश)
उदाहरण के लिए, टर्मिनल में, आप टैब सेट कर सकते हैं रोकें इस आदेश के साथ 4 करने के लिए;
tabs 4; printf "ab\tcd\tde\n"
उत्पादन
ab cd de
बस निम्नलिखित कोड का उपयोग करें:
tabs -n
जहाँ n रिक्त स्थान की संख्या है जो आप को भी टैब चाहिए। हर बार जब आप शेल शुरू करते हैं, तो ऐसा नहीं करने के लिए, बस अपने .bash_profile
को संपादित करें ~/
और फ़ाइल के अंत में उपरोक्त पंक्ति जोड़ें।
टैब कमांड के बारे में अधिक जानकारी के लिए, यहां देखें:
man tabs
ls
लिए पुट ठीक से संरेखित नहीं हो सकता है)।
टैब या टैब के बंद होने की कोई धारणा नहीं है cat
; कार्यक्रम सिर्फ आउटपुट के लिए इनपुट फ़नल करता है और किसी अन्य वर्ण की तरह टैब का व्यवहार करता है। यदि आउटपुट डिवाइस टर्मिनल होता है, तो टर्मिनल जो भी व्यवहार प्रदान करने के लिए कॉन्फ़िगर किया गया है, उसके अनुसार टैब संभाला जाएगा।
POSIX.1 को लागू करने वाले सिस्टम में एक कमांड होता है tabs(1)
जो टर्मिनल की अवधारणा को समायोजित करेगा कि टैब को कैसे प्रदर्शित किया जाना चाहिए। किसी विशेष टैब लेआउट के आधार पर एक अच्छा विचार नहीं माना जाता है, क्योंकि कोई व्यक्ति आपकी फ़ाइल को किसी अन्य डिवाइस जैसे कि एक प्रिंटर के रूप में भेज सकता है जो कि आपके इच्छित उद्देश्य को पूरा नहीं करेगा।
जब आप (या सादे ) ts
में समायोजित करते हैं, तो आप जो कर रहे हैं वह समायोजित कर रहा है कि कैसे प्रदर्शित होने पर संपादक टैब वर्णों की व्याख्या करता है। यह फ़ाइल में समाप्त होता है पर कोई असर नहीं है।vim
vi
उपरोक्त उत्तरों और उदाहरणों के आधार पर, ऐसा लगता है कि ओपी चाहता था कि वास्तविक कमांड है ...
cat somefile | expand -t4
यह मेरे लिए Red Hat 6.4 पर काम करता है।
पहले से दिए गए उत्तरों पर विस्तार करने के लिए, expand
टैब स्टॉप पदों की सूची भी ले सकते हैं। यह उपयोगी है यदि वैरिएबल कॉलम की सामग्री लंबाई बहुत भिन्न होती है।
मैं आज इस आवश्यकता से अधिक आया जब मैं openssl ciphers
अधिक पठनीय का उत्पादन करना चाहता था :
$ openssl ciphers -v 'HIGH'|tr -s ' ' '\t'|expand -t31,41,57,70,90
ECDHE-RSA-AES256-GCM-SHA384 TLSv1.2 Kx=ECDH Au=RSA Enc=AESGCM(256) Mac=AEAD
ECDHE-ECDSA-AES256-GCM-SHA384 TLSv1.2 Kx=ECDH Au=ECDSA Enc=AESGCM(256) Mac=AEAD
ECDHE-RSA-AES256-SHA384 TLSv1.2 Kx=ECDH Au=RSA Enc=AES(256) Mac=SHA384
ECDHE-ECDSA-AES256-SHA384 TLSv1.2 Kx=ECDH Au=ECDSA Enc=AES(256) Mac=SHA384
...
ECDH-ECDSA-AES128-SHA SSLv3 Kx=ECDH/ECDSA Au=ECDH Enc=AES(128) Mac=SHA1
AES128-GCM-SHA256 TLSv1.2 Kx=RSA Au=RSA Enc=AESGCM(128) Mac=AEAD
AES128-SHA256 TLSv1.2 Kx=RSA Au=RSA Enc=AES(128) Mac=SHA256
AES128-SHA SSLv3 Kx=RSA Au=RSA Enc=AES(128) Mac=SHA1
CAMELLIA128-SHA SSLv3 Kx=RSA Au=RSA Enc=Camellia(128) Mac=SHA1
PSK-AES128-CBC-SHA SSLv3 Kx=PSK Au=PSK Enc=AES(128) Mac=SHA1
केवल प्रयोग expand -t31
से आउटपुट की चौड़ाई लगभग 100 वर्णों से 160 वर्णों से अधिक हो जाएगी।
column
:openssl ciphers -v 'HIGH' | column -t
कई टर्मिनल चर टैब स्टॉप की स्थापना का समर्थन करते हैं। जो कि vt100, linux हैं और या EMCA-48 स्टैंडर्ड डू का समर्थन करते हैं, linux सपोर्ट सेटिंग टैब की सबसे ज्यादा शर्तें हैं: xterm और फ़ैमिली (uxterm, urxvt) xfce4-terminal, luit, Terminal, SecureTTY, अन्य।
इसलिए कुछ साल पहले एक स्क्रिप्ट लिखी थी कि हर 2 जगहों पर लॉगिन करने के लिए मेरा टैब सेट करें - 4 का उपयोग करें, फिर 3 को थोड़े समय के लिए, और अब 2 पर…।
इसलिए अब, अगर मैं एक फ़ाइल को 'कैट' करता हूं, तो फ़ाइल में टैब मेरे टर्मिनल की सेटिंग तक विस्तृत होगा।
यदि मुझे विम या अधिक के माध्यम से मिला है, तो वे अपना स्वयं का टैब विस्तार करते हैं, लेकिन बहुत सारे उपयोग टैब का उपयोग करते हैं।
संदर्भ के लिए यहां स्क्रिप्ट शामिल होगी, और या व्यक्तिगत उपयोग:
#!/bin/bash -u
#console_codes(4) man page... vt100/2 et && EMCA-48 standard
# (c) la walsh (2013) -- free to use and modify for personal use.
# -- optionally licenced under Gnu v3 license.
# v0.0.3 - try to reduce tabcols to minimal set to reproduce.
# v0.0.2 - set tabs for full terminal width (try to get term width)
shopt -s expand_aliases extglob
alias my=declare
alias int='my -i' array='my -a' intArray='my -ia' string=my
my _Pt=$(type -t P)
[[ $_Pt && $_Pt == function ]] && unset -f P
alias P=printf
unset _Pt
P -v clrallts "\x1b[3g" #Clear All TabStops
P -v hts "\033H" #Horizontal TabStop
P -v cpr "\x1b[6n" #Current Position Report
getcols() { # try to read terminal width
local sttyout="$(stty size </dev/tty)"
int default_cols=80
if [[ -n ${COLUMNS:-""} && $COLUMNS =~ ^[0-9]+$ ]]; then
default_cols=$COLUMNS; fi
[[ -z ${sttyout:-""} ]] && { echo $default_cols; return 0; }
int cols="${sttyout#*\ }"
echo -n $[cols<2?default_cols:cols]
return 0
}
getpos () {
string ans wanted=${1:-xy}
int attempt=0 max_attempt=1 # in case of rare failure case
# use 'attempt' value as additional
# time to wait for response
while : ; do
( ( P "\x1b[6n" >/dev/tty) & 2>/dev/null )
read -sd R -r -t $[2 + attempt] ans </dev/tty;
ans=${ans:2};
int x=0-1 y=0-1
if ! x="${ans#*;}" y="${ans%;*}" 2>/dev/null ||
((x==-1||y==-1)); then
((attempt+=1 < max_attempt)) && continue
fi
break; done
string out=""
[[ $wanted =~ x ]] && out="$x"
[[ $wanted =~ y ]] && out="${out:+$x }$y"
[[ $out ]] && echo -n "$out"
}
declare -ia tabs
get_tabs () {
P "\r"
tabs=()
int pos=0 oldpos=0-1
while ((oldpos!=pos));do
((pos)) && tabs+=($pos)
oldpos=pos
P "\t"
pos=$(getpos x)
done
P "\r"
return 0
}
# Note: this func uses ability to _read_ tabstops as _proxy_ for setting them
# (i.e. it makes no sense to be able to read them if you can't set them)
test_tabset_ability () {
string prompt="tty_tab:"
int newcol=${#prompt}+1
P "\r$prompt"
int mycol=$(getpos x)
((mycol && mycol==newcol)) && return 0 ## return OK
{ P " Term tabset ability not detected mycol=${mycol:-''},"
P " promptlen=$newcol)\n"; } >&2
exit -1
}
do_help_n_display_curtabs () {
P " <n> - set tab stop to N\r"
intArray diffs;
int last=1 cur i
string eol=""
get_tabs && {
for ((i=0; i<${#tabs[@]}; ++i)); do
cur=${tabs[i]}
diffs[i]=cur-last
last=cur
done
intArray reverse_tabs_set=()
int prevtab=0-1
for ((i=${#diffs[@]}-2; i>0; --i)); do
int thistab=${diffs[i]}
if ((thistab!= prevtab)) ;then
reverse_tabs_set+=($thistab)
prevtab=thistab
fi
done
P "current value: tty_tab "
for ((i=${#reverse_tabs_set[@]}-1; i>=0; --i)); do
P "%d " "${reverse_tabs_set[i]}"; done
P "\r";
}
get_tabs && {
P "(from 1, tabs skip to column: "
P "%s " "${tabs[@]}"
P "\r\n"
}
}
set_tabs () {
int max_col=${1:=0-80}
int tabstop=${2:-?"need a param for tabstop"}
int tab=$tabstop pos=0
string str=""
P $clrallts ## reset old tabs
while ((++pos<cols)) ;do ## move across screen setting tabs
str+=" "
((pos%tab)) || str+="$hts"
done
P "\r$str\r"
}
int cols=$(getcols)
test_tabset_ability ## exits if no ability
if (($#==0)) ; then
do_help_n_display_curtabs
exit 1
else
set_tabs "$cols" "$@"
fi
# vim: ts=2 sw=2
आशा करता हूँ की ये काम करेगा...
मैनपेज के अनुसार, बिल्ली अपने दम पर ऐसा नहीं कर सकती। लेकिन आप अपनी tr
इच्छानुसार किसी भी स्थान के साथ टैब को बदलने के लिए फ़िल्टर के माध्यम से बिल्ली से आउटपुट को चला सकते हैं :
cat somefile | tr '\t' ' '
टैब वर्ण को दो स्थानों से प्रतिस्थापित करेगा।
अपडेट: जैसा कि इस पोस्ट की टिप्पणियों में बताया गया है, यह वास्तव में काम नहीं करता है। फिर भी, मैं इसका जवाब एक उदाहरण के रूप में दे रहा हूं कि यह कैसे करना है।
'\t'
में केवल एक ही स्थान के साथ बदल रहा है, चाहे वह दूसरे स्थान के उद्धरणों की दूसरी जोड़ी के बीच में क्यों न हो' '
tr
कि जिस तरह से काम नहीं करता है .. प्रत्येक बाइट आर्ग 1 में से प्रत्येक के लिए इसी द्वारा दिया जाता है बाइट ..... आर्ग 2 की इसलिए printf '\t' |tr '\t' 'ळ'
एक एकल बाइट जिसका हेक्स मान है बाहर प्रिंट \xE0
.. जो तीन UTF-8 के पहले बाइट है एन्कोडेड बाइट्स जो चरित्र को बनाते हैं ळ
(जिसका यूनिकोड कोडप्वाइंट वैल्यू U + 0933 है)
expand
(कोरुटिल्स पैकेज से) औरtabs
(नेकर्स पैकेज से) कमांड, (2)। और ts का अर्थ है [ T ] ab [ S ] शीर्ष