ฉันมีสตริงเช่นนั้น:
|abcdefg|
และฉันต้องการรับสายอักขระใหม่ที่เรียกว่า Someway (เช่น string2) ด้วยสายอักขระดั้งเดิมโดยไม่มี|
อักขระสองตัวที่เริ่มต้นและท้ายสุดเพื่อให้ฉันมี:
abcdefg
เป็นไปได้ในการทุบตี?
ฉันมีสตริงเช่นนั้น:
|abcdefg|
และฉันต้องการรับสายอักขระใหม่ที่เรียกว่า Someway (เช่น string2) ด้วยสายอักขระดั้งเดิมโดยไม่มี|
อักขระสองตัวที่เริ่มต้นและท้ายสุดเพื่อให้ฉันมี:
abcdefg
เป็นไปได้ในการทุบตี?
คำตอบ:
คุณทำได้
string="|abcdefg|"
string2=${string#"|"}
string2=${string2%"|"}
echo $string2
หรือถ้าความยาวสตริงของคุณคงที่คุณสามารถทำได้
string="|abcdefg|"
string2=${string:1:7}
echo $string2
นอกจากนี้ควรทำงาน
echo "|abcdefg|" | cut -d "|" -f 2
นอกจากนี้ยัง
echo "|abcdefg|" | sed 's/^|\(.*\)|$/\1/'
awk
ทางออกที่ยอดเยี่ยมเสมอ awk
ฉันต้องการที่จะเรียนรู้
IFS='|' read string2 <<< $string
:)
"${string:1:-1}"
man bash
ในหัวข้อ
นี่คือวิธีแก้ปัญหาที่ไม่ขึ้นกับความยาวของสตริง (bash):
string="|abcdefg|"
echo "${string:1:${#string}-2}"
การโพสต์บางรายการไว้ที่นี่ดูเหมือนว่าวิธีที่ง่ายที่สุดคือ:
string="|abcdefg|"
echo ${string:1:-1}
แก้ไข: ทำงานบน Ubuntu กับทุบตี 4.2; ไม่ทำงานบน centOS ด้วย bash 4.1
อีกวิธีหนึ่งคือการใช้head
& tail
คำสั่ง:
$ echo -n "|abcdefg|" | tail -c +2 | head -c -2
abcdefg
[something something]
เป้าหมายเพื่อตัดวงเล็บดังนั้นจึงเป็นecho "[something something]" | tail -c +2 | head -c -2
ไปได้ ขอบคุณสำหรับเคล็ดลับ!
echo -n "|abcdefg|" | tail -c +2 | head -c -1
เห็นได้ชัดว่ามันควรจะเป็น ฉันไม่แน่ใจว่าทำไมการแก้ไขของฉันถูกปฏิเสธ ... มันน่าเศร้ามากที่จะซื่อสัตย์ ดูman head
ข้อมูลเพิ่มเติม
และอีกหนึ่ง:
string="|abcdefg|"
echo "${string//|/}"
คุณยังสามารถใช้ sed เพื่อลบ | ไม่เพียงอ้างอิงสัญลักษณ์ แต่ใช้การอ้างอิงตำแหน่งใน:
$ echo "|abcdefg|" | sed 's:^.\(.*\).$:\1:'
abcdefg
โดยที่ ':' เป็นตัวคั่น (คุณสามารถแทนที่ด้วย / หรืออักขระใด ๆ ที่ไม่ได้อยู่ในแบบสอบถามเครื่องหมายใด ๆ ที่ตามมาจะทำ) ที่นี่ ^ (คาเร็ต) หมายถึงที่จุดเริ่มต้นของสตริงอินพุตและ $ (ดอลลาร์) หมายถึง ในตอนท้าย ส่วน (จุด) ว่ามันอยู่หลังเครื่องหมายรูปหมวกและตัวที่อยู่ก่อนเครื่องหมายดอลลาร์แสดงถึงอักขระตัวเดียว ดังนั้นในคำอื่น ๆ เราจะลบตัวอักษรแรกและตัวสุดท้าย โปรดทราบว่าการดำเนินการนี้จะลบอักขระใด ๆ แม้ว่า | ไม่มีอยู่ในสตริง
EX:
$ echo "abcdefg" | sed 's:^.\(.*\).$:\1:'
bcdef
วิธีการ verbose อีกเล็กน้อย แต่ทำงานในประเภทแรกและตัวละครสุดท้ายไม่จำเป็นต้องเหมือนกัน แนวคิดพื้นฐานคือเรากำลังรับตัวแปรอ่านตัวอักษรเป็นตัวอักษรและต่อท้ายเฉพาะที่เราต้องการให้เป็นตัวแปรใหม่
นี่คือแนวคิดทั้งหมดที่จัดรูปแบบเป็นฟังก์ชันที่ดี
crop_string_ends() {
STR="$1"
NEWSTR=""
COUNT=0
while read -n 1 CHAR
do
COUNT=$(($COUNT+1))
if [ $COUNT -eq 1 ] || [ $COUNT -eq ${#STR} ]
then
continue
fi
NEWSTR="$NEWSTR"$CHAR
done <<<"$STR"
echo $NEWSTR
}
และนี่คือฟังก์ชั่นการทำงานเดียวกัน:
$> crop_string_ends "|abcdefg|"
abcdefg
$> crop_string_ends "HelloWorld"
elloWorl
>>> mystring="|abcdefg|"
>>> print(mystring[1:-1])
abcdefg
หรือบนบรรทัดคำสั่ง:
$ python -c 'import sys;print sys.stdin.read()[1:-2]' <<< "|abcdefg|"
abcdefg
$ echo "|abcdefg|" | awk '{print substr($0,2,length($0)-2)}'
abcdefg
$ ruby -ne 'print $_.split("|")[1]' <<< "|abcdefg|"
abcdefg
โซลูชันขนาดเล็กและสากล:
expr "|abcdef|" : '.\(.*\).'
พิเศษในกรณีนี้และอนุญาตให้ '|' ตัวละครอาจอยู่ที่นั่นหรือไม่:
expr "|abcdef" : '|*\([^|]*\)|*'
$ string="|abcdefg|"
$ string="${string#?}" && string="${string%%?}"
$ echo "$string"
abcdefg
จากhttp://tldp.org/LDP/abs/html/parameter-substitution.html
${var#Pattern}
นำออกจากสั้นที่สุดส่วนหนึ่งของที่ตรงกับปลายด้านหน้าของ นำออกจากยาวที่สุดส่วนหนึ่งของที่ตรงกับปลายด้านหลังของ$var
$Pattern
$var
${var%%Pattern}
$var
$Pattern
$var
awk -F\| '{ print $2 }' <<<"|string|"