java如何实现替换指定位置的指定字符串的功能
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java如何实现替换指定位置的指定字符串的功能相关的知识,希望对你有一定的参考价值。
功能类似:
String sql = "select * from teacher where id = ? and name = ?";
写一个方法public String ReplaceString (String str,String rstr,int a);
如:ReplaceString(sql,"name",1);这里想要的结果是将第二个?号替换为"name"
ReplaceString(sql,"101",0);这里想要的结果是将第一个?号替换为"101"?
请问有没有人实现过这种功能 ??
public class Demo1
public static void main(String[] args)
StringBuffer buffer = new StringBuffer("123456");
System.out.println(buffer.toString());//输出123456
buffer.replace(0, 1, "a");
System.out.println(buffer.toString());//输出a23456
这里简单介绍一下replace方法的使用,replace方法一共有三个参数,第一个参数是指定要替换的字符串的开始位置,第二个参数是指定要替换的字符串的结束位置(注意这里的结束位置不包括本身),第三个参数是指定想将字符串替换成什么内容。
如:原字符串内容为"123456",现在调用replace(0, 2, "abc"),原字符串变为"abc3456" 参考技术A 可以使用StringBuffer定义字符串,之后使用replace方法替换指定位置的字符串为指定的字符串内容,如下代码:
public class Demo1
public static void main(String[] args)
StringBuffer buffer = new StringBuffer("123456");
System.out.println(buffer.toString());//输出123456
buffer.replace(0, 1, "a");
System.out.println(buffer.toString());//输出a23456
这里简单介绍一下replace方法的使用,replace方法一共有三个参数,第一个参数是指定要替换的字符串的开始位置,第二个参数是指定要替换的字符串的结束位置(注意这里的结束位置不包括本身),第三个参数是指定想将字符串替换成什么内容。
如:原字符串内容为"123456",现在调用replace(0, 2, "abc"),原字符串变为"abc3456" 参考技术B /**
* @作者 王建明
* @创建日期 2013-07-15
* @创建时间 14:25:59
* @版本号 V 1.0
*/
public class CosTest
public static void main(String[] args)
String sql = "select * from teacher where id = ? and name = ?";
System.out.println(replaceString(sql,"101",2));
public static String replaceString(String str, String rstr, int a)
String searchStr = "?";
int index = str.indexOf(searchStr);
int count = 1;
while (count != a)
index = str.indexOf(searchStr, index + 1);
count++;
return str.substring(0, index) + rstr + str.substring(index + 1);
追问
测试代码 :
String sql = "select * from teacher where id = ? and name = ?";
sql = replaceString(sql,"101",1);
System.out.println(sql);
sql = replaceString(sql, "lily", 2);
System.out.println(sql);
这样的话会报异常,如何解
解决方法如下:
String result1 = replaceString(sql, "101", 1);
System.out.println(result1);
String result2 = replaceString(sql, "lily", 2);
System.out.println(result2);本回答被提问者采纳 参考技术C //通用一些,按照位置去替换,不管这个位置是什么字符。
public static String replaceString(String str,String rstr,int startIndex)
if(startIndex>str.length()-1)
throw new ArrayIndexOutOfBoundsException("越界了");
String preStr = str.substring(0,startIndex);
String subStr = str.substring(startIndex+1);
return preStr+rstr+subStr;
参考技术D 搜索?的下标,拆分字符串,再组装字符串。
比如说,将所有?的下标存储在list里面或者数组里面,或者map里面
要替换第几个,就按第几个?号所在的下标来拆分字符串。然后拼接新字符串追问
这个在拆分的时候会出现一个问题,那就是如果这个字符串带有空格,会报异常
追答下标没越界应该不报异常吧。实在报异常。先处理空格。比如记下空格所在的下标之类。或者直接先用特殊字符替换空格
shell 如何取文本中 指定两个字符中间的内容
要取TABLE "bank".与row size中间的字符串 如下面的:cpdmdyb_ck
TABLE "bank".cpdmdyb_ck row size = 143 number of columns = 3 index size = 106
unload file name = cpdmd06141.unl number of rows = 1822
TABLE "bank".cpdmdyb_dk row size = 143 number of columns = 3 index size = 106
unload file name = cpdmd06143.unl number of rows = 12310
或者:
awk -F. '/TABLE/split($2,a," ");print a[1]' yourfile结果都是:
cpdmdyb_ck
cpdmdyb_dk
这个可以用非常感谢,第二行带.unl的怎么取出来呢,如:cpdmd06141.unl
追答我看到你的另一个提问了,见那个回答。
用sed的N命令将TABLE "bank"的下一行也读取到模式空间内,并合并为一行(换行符\n分隔)后一起处理。
你在那里面把脚本写出来嘛,我不会写,我在那边把分给你
追答那边写出来了。这里也放一下。
sed -nr '/TABLE/N;s/.*"bank"\\.(.+) row.*\\n.*name = (.+) number.*/load from \\2 insert into \\1;/;p' file.txt 参考技术B ▶ xsel -o|perl -e '$_=<>; /bank\"\.(.*)row/; print $1;'cpdmdyb_ck追问
文件名在那里啊
追答cat xxxx文件名|perl -e 'while($_=) /bank\"\.(.*)row/; print $1;'
追问我要用 TABLE "bank".与row size TABLE 加在那呢,取出来要显示为:
cpdmdyb_ck
cpdmdyb_dk
上面的命令显示在一行了如下
cpdmdyb_ck cpdmdyb_dk
帮我再改下,非常感谢
能不能把下面的cpdmd06141.unl 与cpdmdyb_ck连接起来比如:
laod from cpdmd06141.unl insert into cpdmdyb_ck
最后的输出,改成这样
print "$1\n"
就是附加一个回车。
执行后输出的内容中有重复记录:
ryjsb
ryjsb
khjltzb
khjltzb
khb
khb
grkhfzb
grkhfzb
khsfqrb
khsfqrb
文本中没有重复的行
哦。我以为你的数据是规则的,每行都有。加一个判断就是。
cat xxxxx|perl -e 'while() if(/bank\"\.(.*)row/)print "$1\n";'
以上是关于java如何实现替换指定位置的指定字符串的功能的主要内容,如果未能解决你的问题,请参考以下文章