http://blog.csdn.net/pipisorry/article/details/43303145
java判断字符串包含某个字符段
1. 用indexOf()方法
String str = "1234567";
if(str.indexOf("23") != -1) {}
2. 用repalce()方法
public class Test { public static void main(String[] args) { String s1 = "abc"; String s2 = "1111abcdefe"; if(s2.contains(s1)){ System.out.println("s2包含了s1"); //删掉s1 s2 = s2.replace(s2.substring(s2.indexOf(s1), s2.length()), ""); System.out.println(s2); }else{ System.out.println("s2不包含s1"); } } }
Java将字符转成字符串
1. String str = String.valueOf(ch)2. char c = 'a'; String s = "" + c;
Java获取指定位置上某个字符
char c = string.charAt(int index);
Java正则表达式在字符串中插入字符
在字符串中日期1985[.07]-(- ——等等)1988[.12]前面插入句号,已经是 。 :;不插入,是. 等等替换
1. // 处理简历中的句号
String[] tmpResumeContents = resumeContent
.split("[((]*[\\d]{4}.[\\d]{2}[-——-]*[[\\d]{4}.[\\d]{2}]*");// 1985.07-1988.12
// for (String tmpResumeContent : tmpResumeContents)
// System.err.println("^^^^^^^^^" + tmpResumeContent);
StringBuffer original = new StringBuffer(resumeContent);
// System.err.println("^^^^^^^^^" + original);
for (String tmpResume : tmpResumeContents) {
// System.err.println("**************" + tmpResume
// +"tmpResume.length(): " + );
if (tmpResume.length() != 0
&& !(original.indexOf(tmpResume) + tmpResume.length() == original.length())
&& (!(original.toString().charAt(original.indexOf(tmpResume) + tmpResume.length() - 1) + "")
.matches("[。:;]")))
if ((original.toString().charAt(original.indexOf(tmpResume) + tmpResume.length() - 1) + "")
.matches("[.,,]")) {
// System.err.println("^^^^^^^^^"+(original.toString().charAt(original.indexOf(tmpResume)+
// tmpResume.length() - 1)));
original.replace(original.indexOf(tmpResume) + tmpResume.length() - 1,
original.indexOf(tmpResume) + tmpResume.length(), "。");
} else {
int insertPoint = 0;
do {
// System.err.println("^^^^^^^^^" +
// original);
// System.err.println("***" + tmpResume);
// System.out.println("***" + insertPoint);
insertPoint = original.indexOf(tmpResume, insertPoint) + tmpResume.length();
// System.out.println("&&&" + insertPoint +
// "&&&" +
// original.toString().charAt(insertPoint));
} while ((insertPoint < original.length())
&& !(("" + original.toString().charAt(insertPoint)).matches("[\\s]*[\\d((]*")));
// System.err.print("***" + tmpResume);
// System.err.print("&&&" + insertPoint + "&&&"
// + original.toString().charAt(insertPoint)
// + "\n");
original.insert(insertPoint, "。");
}
}
resumeContent = original.toString();// 因为resumeContent.indexOf要时时更新
resumeContent = endWithDot(resumeContent);
// System.err.println("***************" + resumeContent);
2. lastIndexOf(String str):反向索引 解决可能两次匹配情况
do_while循环解决多次匹配情况
3. 取出日期来匹配,不用日期spilt后的字符串匹配,就没有多次匹配出现了
java判断一个字符串中是否包含某几个字符(使用正则表达式)
1. string.matches(".*[【(个人)]*简\\s*[介历]*[】]*:*.*")
string.charAt(0) + "").matches("[,,]")
note:matches("[;;.::。]")中要有[],否则是匹配整个字符串
2.【http://www.111cn.net/jsp/Java/52101.htm】
http://blog.163.com/zzcc_8/blog/static/1603547220101111127306/
http://www.cxyclub.cn/n/59606/
Java的java.util.regex包
Java爬虫中文乱码处理
package Test;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.net.URLEncoder;
public class EncodeConvert {
public static void main(String[] args) {
System.out.println(getencode("赵景山"));
System.out.println(getDecode("%D5%D4%BE%B0%C9%BD"));
}
// 中文转码
public static String getencode(String str) {
String encodeStr = null;
try {
// 编码类型为gbk
encodeStr = URLEncoder.encode(str, "gbk");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return encodeStr;
}
// 解码
public static String getDecode(String str) {
String decodeStr = null;
try {
// 编码类型为gbk
decodeStr = URLDecoder.decode(str, "gbk");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return decodeStr;
}
}
from:http://blog.csdn.net/pipisorry/article/details/43303145
ref:java中String的七种用法