Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 396|回复: 0

[Java基础知识]解析csv格式的java函数

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-2 09:27:30 | 显示全部楼层 |阅读模式
    我们经常将Excel格式的文件保存为csv格式以方便上传和修改,可是当数据中包含逗号和双引号的时候Excel会把该字段用双引号括住并把数据中的"改为"",从而给解析带来了困难。我写了以下函数来解析这样的字符串: testSplitCSV.java: import java.util.Vector;
    class  testSplitCSV{
      /**
      * Split one line of csv file
      * @return a String array results
      */
      public static String[] splitCSV(String src) throws Exception{
       if (src==null || src.equals("")) return new String[0];
       StringBuffer st=new StringBuffer();
       Vector result=new Vector();
       boolean beginWithQuote = false;
       for (int i=0;i<src.length();i++){
        char ch = src.charAt(i);
        if (ch=="""){
         if (beginWithQuote){
          i++;
          if (i>=src.length()){
           result.addElement(st.toString());
           st=new StringBuffer();
           beginWithQuote=false;
          }else{
           ch=src.charAt(i);
           if (ch == """){
            st.append(ch);
           }else if (ch == ","){
            result.addElement(st.toString());
            st=new StringBuffer();
            beginWithQuote = false;
           }else{
            throw new Exception("Single double-quote char mustn"t exist in filed "+(result.size()+1)+" while it is begined with quote
    char at:"+i);
           }
          }
         }else if (st.length()==0){
          beginWithQuote = true;
         }else{
          throw new Exception("Quote cannot exist in a filed which doesn"t begin with quote!
    field:"+(result.size()+1));
         }
        }else if (ch==","){
         if (beginWithQuote){
          st.append(ch);
         }else{
          result.addElement(st.toString());
          st=new StringBuffer();
          beginWithQuote = false;
         }
        }else{
         st.append(ch);
        }
       }
       if (st.length()!=0){
        if (beginWithQuote){
         throw new Exception("last field is begin with but not end with double quote");
        }else{
         result.addElement(st.toString());
        }
       }
       String rs[] = new String[result.size()];
       for (int i=0;i<rs.length;i++){
        rs=(String)result.elementAt(i);
       }
      return rs;
      }  public static void main(String[] args){
       String src1=  ""fh,zg",sdf,"asfs,",",dsdf","aadf""","""hdfg","fgh""dgnh",hgfg"dfh,"asdfa""""","""""fgjhg","gfhg""""hb"";
       try {
        String[] Ret = splitCSV(src1);
        for (int i=0;i<Ret.length;i++){
         System.out.println(i+": "+Ret);
        }
       }
       catch(Exception e) {
        e.printStackTrace();
       }
      }
    } 程序运行结果: D:java>java testSplitCSV
    0: fh,zg
    1: sdf
    2: asfs,
    3: ,dsdf
    4: aadf"
    5: "hdfg
    6: fgh"dgnh
    7: hgfg"dfh
    8: asdfa""
    9: ""fgjhg
    10: gfhg""hb
      
       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/10/2/092729797.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 22:20 , Processed in 0.363616 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表