java csv 文件 操作类
一个CSV文件操作类,功能比较齐全:
package tool; import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Vector;
//参考 http://wenku.baidu.com/view/dfc319c689eb172ded63b7ee.html
public class CsvUtil {
private String fileName=null;
private BufferedReader bufferedReader=null;
private Vector v=new Vector(); public CsvUtil(String filename) throws IOException
{
this.fileName=filename;
bufferedReader=new BufferedReader(new FileReader(fileName));
String stemp;
while((stemp=bufferedReader.readLine())!=null)
{
if(!stemp.startsWith("#"))//以#开头表示注释
v.add(stemp); } }
public Vector getVector()
{
return v;
}
//得到CSV的行数
public int getRowCount()
{
return v.size();
} //取得指定行 public String getRow(int index)
{
if(this.getRowCount()==0)
return null;
return (String)v.get(index);
}
//取得指定列
public String getColumn(int index)
{
if(this.getColumnCount()==0)
{
return null;
}
StringBuffer scol=new StringBuffer();
String temp=null;
int column=this.getColumnCount();
if(column>=1)
{
for(Iterator it=v.iterator();it.hasNext();)
{
temp=it.next().toString();
scol=scol.append(temp.split(",")[index]+","); }
} String str=new String(scol.toString());
str=str.substring(0,str.length()-1);
return str; }
//得到列数
public int getColumnCount()
{
if(!v.toString().equals("[]"))
{
if(v.get(0).toString().contains(","))
{
return v.get(0).toString().split(",").length;
}
else if(v.get(0).toString().trim().length()!=0)
{
return 1;
}
else
{
return 0;
} }
else
{
return 0; } } //取得指定行,指定列的值
public String getValueAt(int row,int col)
{
String temp=null;
int column=this.getColumnCount();
if(column>=1)
{
temp=v.get(row).toString().split(",")[col];
} else
{
temp=null;
}
return temp; } public void insertRow(Vector v) throws IOException
{
//当前的vector增加
// this.v.add错误 BufferedWriter bw=new BufferedWriter(new FileWriter(this.fileName,true));//一定要接true,表示追加
StringBuffer temp=new StringBuffer();
Iterator it=v.iterator();
temp.append(it.next().toString());
if(v.size()>1)
{
while(it.hasNext())
{
temp.append(","+it.next().toString());
}
}
bw.write(temp.toString());
bw.newLine();
bw.flush();
bw.close(); }
public void deleteRow(int index) throws IOException
{
v.remove(index); BufferedWriter bw=new BufferedWriter(new FileWriter(this.fileName));
for(Iterator it=v.iterator();it.hasNext();)
{
bw.write(it.next().toString());
bw.newLine();//一定要有 }
bw.flush();
bw.close(); } public void printAll()
{
Iterator it=v.iterator();
while(it.hasNext())
{
System.out.println(it.next().toString());
}
} public void CsvClose() throws IOException
{
this.bufferedReader.close();
} public static void main(String[] args) throws IOException
{
CsvUtil cu=new CsvUtil("data/user.txt");
/*
String s11=cu.getValueAt(1, 1);
System.out.println(s11);
String arr1=cu.getRowCount(0);
System.out.println(arr1);
System.out.println(cu.getColumn(0));
*/
Vector v=new Vector();
v.add("user5");
v.add("pwd5");
cu.insertRow(v);
//cu.deleteRow(2);
cu.printAll(); }
}
java csv 文件 操作类的更多相关文章
- java的文件操作类File
java.io.File类,是java获取文件/文件夹的所有属性,和完成所有相关操作的类 例子: package test.file.IO; import java.io.*; public clas ...
- java FileUtil(文件操作类)
package tools; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; i ...
- Java文件操作类效率对比
前言 众所周知,Java中有多种针对文件的操作类,以面向字节流和字符流可分为两大类,这里以写入为例: 面向字节流的:FileOutputStream 和 BufferedOutputStream 面向 ...
- JAVA文件操作类和文件夹的操作代码示例
JAVA文件操作类和文件夹的操作代码实例,包括读取文本文件内容, 新建目录,多级目录创建,新建文件,有编码方式的文件创建, 删除文件,删除文件夹,删除指定文件夹下所有文件, 复制单个文件,复制整个文件 ...
- 一个封装好的CSV文件操作C#类代码
using System.Data; using System.IO; namespace DotNet.Utilities { /// <summary> /// CSV文件转换类 // ...
- C# 文件操作类大全
C# 文件操作类大全 时间:2015-01-31 16:04:20 阅读:1724 评论:0 收藏:0 [点我收藏+] 标签: 1.创建文件夹 //usin ...
- android 文件操作类简易总结
android 文件操作类(参考链接) http://www.cnblogs.com/menlsh/archive/2013/04/02/2997084.html package com.androi ...
- java中文件操作《一》
在日常的开发中我们经常会碰到对文件的操作,在java中对文件的操作都在java.io包下,这个包下的类有File.inputStream.outputStream.FileInputStream.Fi ...
- 【转载】 C#工具类:Csv文件转换类
CSV是逗号分隔值格式的文件,其文件以纯文本形式存储表格数据(数字和文本).CSV文件由任意数目的记录组成,记录间以某种换行符分隔:每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号 ...
随机推荐
- Android入门——UI(2)
介绍SeekBar拖动条控件.ProgressBar进度条控件.DatePicker日历控件.TimePicker时间控件 <?xml version="1.0" encod ...
- MATLAB中imshow()和image()
MATLAB中imshow()和image(): IMSHOW Display image in Handle Graphics figure. IMSHOW(I) displays the gray ...
- 实现一个简单的邮箱地址爬虫(python)
我经常收到关于email爬虫的问题.有迹象表明那些想从网页上抓取联系方式的人对这个问题很感兴趣.在这篇文章里,我想演示一下如何使用python实现一个简单的邮箱爬虫.这个爬虫很简单,但从这个例子中你可 ...
- 有关std::map和std::vector的使用
先说map吧. 最需要注意的就是:用下标访问map中的元素时,与使用下标访问vector的行为截然不同! 用下标访问不存在的元素时,将导致在map容器中添加一个新的元素,它的键即为该下标! 然而很多时 ...
- C++链接库
静态链接库在程序编译链接过程中就导入lib文件并且包含在生成的exe文件里,而动态链接库DLL是在程序运行中由程序加载和卸载的,也就是说它是动态的,当然动态链接库DLL也可以静态加载当做静态来用: 静 ...
- C++ try catch 捕获空指针异常,数组越界异常
#include <exception> #include <iostream> using namespace std; /************************* ...
- jquery不限图片焦点图
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Java Buffer
1.1 NIO Buffers - Class java.nio.Buffer NIO data transfer is through the so-called buffers implement ...
- 把WinXP装进内存 性能飚升秒杀固态硬盘
现在用户新配置的电脑,内存很少有小于2GB的,配置4GB内存的朋友也有不少.容量如此大的内存,我们在使用电脑的日常操作中绝对用不完.而目前制约系统性能最大的瓶颈就是硬盘的传输速度,所以,这里教你怎么把 ...
- js正则验证"汉字"
var nickname = value; var regex = new RegExp("^([\u4E00-\uFA29]|[\uE7C7-\uE7F3]|[a-zA-Z0-9_]){1 ...