代码:
import java.io.UnsupportedEncodingException;
public class 截取字符串 {
public static void main(String[] args) {
// 将str按[x,y)截断为result
String str = "中b国abc中国好好啊!";
int x = 1;
int y = 5;
String result1 = "";
// 按照字符截取
result1 = substring1(str, x, y);
System.out.println("按照字符截取结果:");
System.out.println(result1);
System.out.println("====================");
String result2 = "";
// 按照字符截取
result2 = substring2(str, x, y);
System.out.println("按照字节截取结果:");
System.out.println(result2);
}
/**
* 按照字符截取
*/
private static String substring1(String str, int x, int y) {
StringBuffer result = new StringBuffer();
// 异常处理
if (str == null) {
result.append("输入异常");
return result.toString();
}
int len = str.length() - 1;
if ((len == -1) || (x >= y) || (len < x) || (len < y)) {
result.append("输入异常");
return result.toString();
}
for (int i = x; i < y; i++) {
char a = str.charAt(i);
result.append(a);
}
return result.toString();
}
/**
* 按照字节截取 GBK按字节获取长度,中文占2字节,非中文占1字节 含有中文的情况:中国好好啊!截取[1,2)获取中,[0,5)中国。
* 即截取[x,y)中x字节所在位对应的那个字符到y字节所在位对应的字符的前一个字符。
*/
private static String substring2(String str, int x, int y) {
StringBuffer result = new StringBuffer();
// 异常处理
if (str == null) {
result.append("输入异常");
return result.toString();
}
int len = -1;
try {
// GBK按字节获取长度,中文占2字节,非中文占1字节
len = str.getBytes("gbk").length - 1;
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
result.append("输入异常");
return result.toString();
}
if ((len == -1) || (x >= y) || (len < x) || (len < y)) {
result.append("输入异常");
return result.toString();
}
// count所在的字节位,i所在的字符位
int count = 0;
for (int i = 0; i < str.length() - 1; i++) {
char a = str.charAt(i);
if (a >= 0x0391 && a <= 0xFFE5) {
count++;
}
if (count >= y) {
return result.toString();
}
if (count >= x) {
result.append(a);
}
count++;
}
return "代码逻辑问题";
}
}
运行结果: