替换指定字符数

时间:2014-01-31 23:20:28

标签: bash sed awk grep

我有这样的事情:

aaaaaaaaaaaaaaaaaaaaaaaaa

我需要一些能让我根据指定的数字从左到右替换ac字符的内容。

例如:

some_command 3应将前{3} a替换为c cccaaaaaaaaaaaaaaaaaaaaaa

some_command 15
cccccccccccccccccaaaaaaaaaa

6 个答案:

答案 0 :(得分:5)

这可以完全用bash完成:

some_command() {
    a="aaaaaaaaaaaaaaaaaaaaaaaaa"
    c="ccccccccccccccccccccccccc"
    echo "${c:0:$1}${a:$1}"
}

> some_command 3
cccaaaaaaaaaaaaaaaaaaaaaa

答案 1 :(得分:4)

使用awk:

s='aaaaaaaaaaaaaaaaaaaaaaaaa'
awk -F "\0" -v n=3 -v r='c' '{for (i=1; i<=n; i++) $i=r}1' OFS= <<< "$s"
cccaaaaaaaaaaaaaaaaaaaaaa

答案 2 :(得分:2)

这可能适合你(GNU sed):

sed -r ':a;/a/{x;/^X{5}$/{x;b};s/$/X/;x;s/a/c/;ba} file

这会在a中用c替换前5个file

sed -r ':a;/a/{x;/^X{5}$/{z;x;b};s/$/X/;x;s/a/c/;ba} file

这将为a中的每一行替换前{5} cfile

答案 3 :(得分:1)

#/bin/bash

char=c
word=aaaaaaaaaaaaaaaaaaaaaaaaa

# pass in the number of chars to replace
replaceChar () {
   num=$1
   newword=""
   # this for loop to concatenate the chars could probably be optimized
   for i in $(seq 1 $num); do newword="${newword}${char}"; done
   word="${newword}${word:$num}"
   echo $word
}

replaceChar 4

答案 4 :(得分:1)

比OP要求的更一般的解决方案,建立在@ anubhava的优秀答案之上。

  • 参数化替换计数以及“之前和之后”字符。
  • “之前”字符匹配在任何地方 - 不仅仅是在输入字符串的开头,以及是否与其他实例相邻。
  • 输入来自stdin,因此可以输入多行。
# Usage:
# ... | some_command_x replaceCount beforeChar afterChar
some_command_x() { 
  awk -F '\0' -v n="$1" -v o="${2:0:1}" -v r="${3:0:1}" -v OFS='' \
    '{
      while(++i <= NF)
       { if ($i==o) { if (++n_matched > n) break; $i=r } }
     { i=n_matched=0; print }
    }'
}

# Example:
some_command_x 2 a c <<<$'abc_abc_abc\naaa rating'

# Returns:
cbc_cbc_abc
cca rating

答案 5 :(得分:0)

Perl有一些可以被利用的有趣功能。定义以下bash脚本some_command

#! /bin/bash
str="aaaaaaaaaaaaaaaaaaaaaaaaa"
perl -s -nE'print s/(a{$x})/"c" x length $1/er' -- -x=$1 <<<"$str"

测试:

$ some_command 5
cccccaaaaaaaaaaaaaaaaaaaa