由于本人经常买一些百度云资料而商家整理的又十分杂乱,如下图每次下载下来大约500多个图片文件,
熟悉的同学们没看错,这就是得到APP里的课程,为了图便宜就从某宝上以低价把所有的课程都买了下来。但是把图片传到手机上看很不方便,因为商家整理的并不是很好,有时候刷到下一张图片就跟上一张不配套了,所以我就打算把每天的课程分文件夹整理,每个文件夹大约有2到3个jpg文件,整理结果如下图:
实现步骤:
首先观察文件名,发现名称格式为qs+日期+标题+页数。那么将文件夹的名字用正则表达式提取创建为日期+标题,图片文件存储名称依旧使用原名。
JAVA的代码如下:
package tian.cheng.shear;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
public class Copy {
public static void main(String[] args) {
long s = System.currentTimeMillis();
String name = null;
File file = new File("E:\\前哨2018\\2018年");
String[] strArr = file.list();
for(String str : strArr){
//System.out.println(str.replaceAll("[^(\\u4e00-\\u9fa5)]", "") );//过滤出文字
//System.out.println(str);//原文件名
//System.out.println(str.replaceAll("[^(0-9)]", "").substring(0, 4));//提取前4个数字
String lstr = str.replaceAll("[^(0-9)]", "").substring(0, 4)+
str.replaceAll("[^(\\u4e00-\\u9fa5)]", "");
FileInputStream fis = null;
FileOutputStream fos = null;
File fil = new File("E:\\前哨2018\\2018\\"+lstr);//创建复制文件夹
if(!fil.exists()){
fil.mkdir();
}
if(fil.isDirectory()) {
File fileList = new File(fil,str);
try {
fileList.createNewFile();
} catch (IOException e1) {
e1.printStackTrace();
}
name = fileList.getName();
System.out.println(fil+"\\"+name);//打印被复制文件路径
}
try{
fis = new FileInputStream(file+"\\"+str);
fos = new FileOutputStream(fil+"\\"+name);
//定义字节数组,缓冲
byte[] bytes = new byte[1024*10];
//读取数组,写入数组
int len = 0 ;
while((len = fis.read(bytes))!=-1){
fos.write(bytes, 0, len);
}
}catch(IOException ex){
System.out.println(ex);
throw new RuntimeException("文件复制失败");
}finally{
try{
if(fos!=null)
fos.close();
}catch(IOException ex){
throw new RuntimeException("释放资源失败");
}finally{
try{
if(fis!=null)
fis.close();
}catch(IOException ex){
throw new RuntimeException("释放资源失败");
}
}
}
}
long e = System.currentTimeMillis();
System.out.println(e-s);
}
}