Replace one substring for another string in shell script

前端 未结 10 1399
猫巷女王i
猫巷女王i 2020-11-22 11:55

I have \"I love Suzi and Marry\" and I want to change \"Suzi\" to \"Sara\".

#!/bin/bash
firstString=\"I love Suzi and Marry\"
secondString=\"Sara\"
# do some         


        
相关标签:
10条回答
  • 2020-11-22 12:08

    It's better to use bash than sed if strings have RegExp characters.

    echo ${first_string/Suzi/$second_string}
    

    It's portable to Windows and works with at least as old as Bash 3.1.

    To show you don't need to worry much about escaping let's turn this:

    /home/name/foo/bar
    

    Into this:

    ~/foo/bar
    

    But only if /home/name is in the beginning. We don't need sed!

    Given that bash gives us magic variables $PWD and $HOME, we can:

    echo "${PWD/#$HOME/\~}"
    

    EDIT: Thanks for Mark Haferkamp in the comments for the note on quoting/escaping ~.*

    Note how the variable $HOME contains slashes but this didn't break anything.

    Further reading: Advanced Bash-Scripting Guide.
    If using sed is a must, be sure to escape every character.

    0 讨论(0)
  • 2020-11-22 12:08
    echo [string] | sed "s/[original]/[target]/g"
    
    • "s" means "substitute"
    • "g" means "global, all matching occurrences"
    0 讨论(0)
  • 2020-11-22 12:11

    I know this is old but since no one mentioned about using awk:

        firstString="I love Suzi and Marry"
        echo $firstString | awk '{gsub("Suzi","Sara"); print}'
    0 讨论(0)
  • 2020-11-22 12:16

    This can be done entirely with bash string manipulation:

    first="I love Suzy and Mary"
    second="Sara"
    first=${first/Suzy/$second}
    

    That will replace only the first occurrence; to replace them all, double the first slash:

    first="Suzy, Suzy, Suzy"
    second="Sara"
    first=${first//Suzy/$second}
    # first is now "Sara, Sara, Sara"
    
    0 讨论(0)
  • 2020-11-22 12:20

    Pure POSIX shell method, which unlike Roman Kazanovskyi's sed-based answer needs no external tools, just the shell's own native parameter expansions. Note that long file names are minimized so the code fits better on one line:

    f="I love Suzi and Marry"
    s=Sara
    t=Suzi
    [ "${f%$t*}" != "$f" ] && f="${f%$t*}$s${f#*$t}"
    echo "$f"
    

    Output:

    I love Sara and Marry
    

    How it works:

    • Remove Smallest Suffix Pattern. "${f%$t*}" returns "I love" if the suffix $t "Suzi*" is in $f "I love Suzi and Marry".

    • But if t=Zelda, then "${f%$t*}" deletes nothing, and returns the whole string "I love Suzi and Marry".

    • This is used to test if $t is in $f with [ "${f%$t*}" != "$f" ] which will evaluate to true if the $f string contains "Suzi*" and false if not.

    • If the test returns true, construct the desired string using Remove Smallest Suffix Pattern ${f%$t*} "I love" and Remove Smallest Prefix Pattern ${f#*$t} "and Marry", with the 2nd string $s "Sara" in between.

    0 讨论(0)
  • 2020-11-22 12:22

    For Dash all previous posts aren't working

    The POSIX sh compatible solution is:

    result=$(echo "$firstString" | sed "s/Suzi/$secondString/")
    

    This will replace the first occurrence on each line of input. Add a /g flag to replace all occurrences:

    result=$(echo "$firstString" | sed "s/Suzi/$secondString/g")
    
    0 讨论(0)
提交回复
热议问题