首页 > 代码库 > Java不规则字符串按照逗号分割的解析方法(字段中又含有逗号)
Java不规则字符串按照逗号分割的解析方法(字段中又含有逗号)
/** * Java字符串逗号分割解析方法 * 本专门针对双引号中还有逗号或者某个字段无双引号的情况而设计的 * 例如要将 字符串 String sss="101,\"a\",\"中国,江苏\",\"b\",\"中国,北京\",1,0,\"c\""按照逗号进行分割解析; * 正确的split的结果是 (101)(a)( 中国,江苏) ( b)( 中国,北京) ( 1)( 0)( c) * 如果用java的split方法的话,当遇到(中国,北京)这些字段值时就会多分割了一个字段出来,就不正确了,同时,上面的101 ,1,0都不带要双引号 * 我们期望的理想字符串当然都是带双引号的字段值组成的字符串了,但是发生上面的情况时我们感觉很恼火 * 以上就是本方法设计的初衷,其实这方法是大学课本数据结构中的提到的,在此用Java实现了一下,但是方法执行的效率我还没有测试 * 如果谁有更好的方法欢迎加入讨论O(∩_∩)O~ * @author HsuChan * @version 2014-11-30 22:30 * @param sss * @return String [] */ public String [] commaDivider(String sss){ //双引号开始标记 int qutationStart =0; //双引号结束标记 int qutationEnd =0; char[] charStr = sss.toCharArray(); //用于拼接字符 作为一个字段值 StringBuffer sbf = new StringBuffer(); //结果list List<String> list = new ArrayList<String>(); //逐个字符处理 for(int i=0;i<charStr.length;i++) { //在此之前还未遇到双引号并且当前的字符为\" if(qutationStart == 0&&charStr[i] == ‘\"‘) { qutationStart = 1; qutationEnd = 0; continue; } else if(qutationStart == 1&&charStr[i] == ‘\"‘){//在此之前遇到了双引号并且当前的字符为\" 说明字段拼接该结束了 qutationStart = 0; qutationEnd = 1; //当最后一个字符是双引号时,由于下次循环不会执行,所以在此保存一下 if(i == charStr.length-1&&sbf.length() != 0) { list.add(sbf.toString()); sbf.setLength(0); } continue; } else if(qutationStart == 1&&charStr[i] == ‘,‘&&qutationEnd == 0) {//处理 \"中国,北京\"这种不规范的字符串 sbf.append(charStr[i]); continue; } else if(charStr[i] == ‘,‘) {//字段结束,将拼接好的字段值存到list中 list.add(sbf.toString()); sbf.setLength(0); continue; } //不属于分隔符的就拼接 sbf.append(charStr[i]); if(i == charStr.length-1&&sbf.length()!=0) { list.add(sbf.toString()); sbf.setLength(0); } } return (String[])list.toArray(new String[list.size()]); }
Java不规则字符串按照逗号分割的解析方法(字段中又含有逗号)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。