java的字符数组扩容_java字符串操作扩充-灵活截取字符串

public class StringUtil {

static int varlen1;

static int varlen2;

static String varstr1;

static String varstr2;

static String varstr3;

public static String indexOf(String sourceStr,String indexStr,int indexNum){

/**

* 原始字符串:sourceStr

* 索引字符串:indexStr

* 固定字符串截取后索引次数的indexNum

*

* indexOf("ws++rq++sl++dl","++",4)

* 结果:dl

*/

varlen1 = sourceStr.length();

varlen2 = indexStr.length();

int i=0;//字符串下标

int n=0;//某字符串在指定字符串中的个数

int m=0;

int x=0;

while (i< varlen1){

varstr1 = sourceStr.substring(i, i);//substr(sourceStr,i,1);

varstr2 = indexStr.substring(1,1);//获取指定用于截串的字符串的第一个字符

if(varstr1.equals(varstr2)){

if(i+varlen2<=varlen1){//判断字符下标

if(indexStr.equals(sourceStr.substring(i, i+varlen2))){

n++;

i=i+varlen2;

}

}

}

i++;

}

x=n;

if(indexNum <= 0){

return "";

}

if(n==0){

return sourceStr;

}

if(indexNum==1){

i=0;

n=0;

while(i

varstr1 = sourceStr.substring(i, i);

varstr2 = indexStr.substring(1, 1);

if(null==varstr3){

varstr3=sourceStr.substring(i, i);

}else

varstr3.concat(sourceStr.substring(i, i));

if(varstr1.equals(varstr2)){

if(indexStr.equals(sourceStr.substring(i, i+varlen2))){

n++;

if(i==0&&n==1){

m=varlen2;

}else{

return sourceStr.substring(m, i);

}

}

}

i++;

}

}./*欢迎加入java交流Q君样:909038429一起吹水聊天

if(indexNum<=n+1){

i=0;

n=0;

int c=0;

while(i

varstr1 = sourceStr.substring(i, i);

varstr2 = indexStr.substring(1, 1);

if(varstr1.equals(varstr2)){

if(indexStr.equals(sourceStr.substring(i, i+varlen2))){

n++;

if(n+1==indexNum){

m=i+varlen2;

c=n;//存储指字符串出现的次数

}

if(n-1==c&&c!=0){

//当上一个条件满足时,下次出现时返回指定索引的字符串

return sourceStr.substring(m, i);

}

i=i+varlen2;

}else

i++;

}else

i++;

}

}

//获取截取后的最后一个字符串

return sourceStr.substring(sourceStr.lastIndexOf(indexStr)+indexStr.length(),sourceStr.length());

}

public static void main(String[] args) {

System.out.println(indexOf("ws++rq++sl++dl","++",3));

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值