package CTY;
import org.junit.Test;
import java.io.File;
public class ClearFile {
static int iFile = 0;
@Test
public void m(){//递归删除空文件夹
// TODO Auto-generated method stub
// dir_str清理文件夹的路径
String dir_str = "C:\\承认书\\";
File dir = new File( dir_str );
clear( dir );
System.out.println( "清理成功。" );
System.out.println( "共清理了" + iFile + "个空文件夹" );
}
public static void clear( File dir )
{
File[] dirs = dir.listFiles();
for( int i = 0; i < dirs.length; i++ )
{
if( dirs[i].isDirectory() )
{
clear( dirs[i] );
}
}
if( dir.isDirectory() && dir.delete() )
iFile++;
System.out.println( dir + "清理成功" );
}
}
package CTY;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import org.junit.Test;
import static CTY.GETuuid.generateShortUuid;
public class CTY {
String dir = "C:\\承认书\\";
@Test
public void MN() throws SQLException, ClassNotFoundException, IOException {
recursiveTraversalFolder(dir);
}
//连接并查询
public static String CONN(String st) throws ClassNotFoundException, SQLException {
String co = null;
Class.forName("oracle.jdbc.driver.OracleDriver");
String dbURL = "jdbc:oracle:thin:@127.0.0.1:1521:orcl";
Connection conn = DriverManager.getConnection(dbURL, "这里填你的用户名", "这里填你的密码");
String str = "select * from BTEAS.T_BD_MATERIAL where FWARRANTNUMBER like '%" + st + "%'";
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(str);
while(rs.next()) {
String s = rs.getString("FNUMBER") +"_"+st+"_"+ rs.getString("FNAME_L2");
co=s;
}
conn.close();
stmt.close();
rs.close();
return co;
}
public static void recursiveTraversalFolder(String path) throws SQLException, ClassNotFoundException, IOException {
File folder = new File(path);
if (folder.exists()) {
File[] fileArr = folder.listFiles();
if (null == fileArr || fileArr.length == 0) {
System.out.println("文件夹是空的!");
return;
} else {
for (File file : fileArr) {
if (file.isDirectory()) {//是文件夹,继续递归,如果需要重命名文件夹,这里可以做处理
//System.out.println("文件夹:" + file.getAbsolutePath() + ",继续递归!");
if(file.getAbsolutePath().contains("CAS")){
String OS=file.getAbsolutePath().substring(file.getAbsolutePath().lastIndexOf("\\"));
if(OS.length()>=9){
String OD=OS.replaceAll("\\\\","").substring(0,9);
System.out.println(file.getAbsolutePath()+"<路径>");
//CONN(OD);
String conn=CONN(OD);
if(conn!=null&&!conn.isEmpty()){
System.out.println(conn+"<已查到>");
CTYS CTYS=new CTYS();
//原路径+新名字//加时间戳在这里处理
CTYS.recursiveTraversalFolder(file.getAbsolutePath(),conn);
}
}
}
recursiveTraversalFolder(file.getAbsolutePath());
} else {//是文件,判断是否需要重命名
}
}
}
}else {
System.out.println("文件不存在!");
}
}
}
package CTY;
import java.io.File;
import java.io.IOException;
import static CTY.GETuuid.generateShortUuid;
public class CTYS {
static int s=0;
public CTYS() {
}
public void recursiveTraversalFolder(String path,String st) throws IOException {
File folder = new File(path);
if (folder.exists()) {
File[] fileArr = folder.listFiles();
if (null == fileArr || fileArr.length == 0) {
System.out.println("文件夹是空的 !");
return;
}
for (int i = 0; i < fileArr.length; ++i) {
if (fileArr[i].isDirectory()) {
this.recursiveTraversalFolder(fileArr[i].getAbsolutePath(),st);
} else {
String fileName = fileArr[i].getName();
File parentPath = fileArr[i].getParentFile();
File newDir = new File(parentPath + "/" + fileName);
if (st!=null&&!st.isEmpty()) {
if(fileArr[i].getName().contains(".xls")
|| fileArr[i].getName().contains(".doc")
|| fileArr[i].getName().contains(".DOC")
|| fileArr[i].getName().contains(".pdf")
|| fileArr[i].getName().contains(".rar")
|| fileArr[i].getName().contains(".RAR")
|| fileArr[i].getName().contains(".PDF")
|| fileArr[i].getName().contains(".JPG")
|| fileArr[i].getName().contains(".jpg")
|| fileArr[i].getName().contains(".zip")
|| fileArr[i].getName().contains(".ZIP")
|| fileArr[i].getName().contains(".ppt")
|| fileArr[i].getName().contains(".txt")){
++s;
String uuid=generateShortUuid();
System.out.println(newDir+"<<<旧路径名字------------新名字>>>"+st.replaceAll("\\*","#").replaceAll("\\|","#").replaceAll("\\\\","#").replaceAll("/","#")+"_"+uuid+fileArr[i].getName().substring(fileArr[i].getName().lastIndexOf("."))+"旧文件数量"+s);
//fileArr[i].renameTo(new File(fileArr[i].getParentFile()+"/"+ st.replaceAll("\\*","#") + "_" + generateShortUuid()+fileArr[i].getName().substring(fileArr[i].getName().lastIndexOf("."))));//重命名
CUT.CUT(newDir,st.replaceAll("\\*","#").replaceAll("\\|","#").replaceAll("\\\\","#").replaceAll("/","#") + "_" + uuid+fileArr[i].getName().substring(fileArr[i].getName().lastIndexOf(".")),"D:\\test002\\");
}
}
}
}
} else {
System.out.println("文件不存在!");
}
}
}
package CTY;
import java.io.*;
public class CUT {
static int sta=0;
public static void CUT(File path, String name,String newpath) throws IOException {
//获取需要剪切的文件
File file = new File(String.valueOf(path));
//创建文件流对象
try {
FileInputStream fis = new FileInputStream(file);
FileOutputStream fos=new FileOutputStream(newpath+name);
//储存读取数据
byte[] bs = new byte[1024];
//储存读取数据量
int count = 0;
//复制
while ((count = fis.read(bs)) != -1) {
fos.write(bs, 0, count);
}
//关闭流
fis.close();
fos.close();
fos.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//删除文件
boolean ntf;
ntf=file.delete();
if(ntf){
++sta;
System.out.println(path+"<已删除>"+sta);
}
}
}
package CTY;
import org.junit.Test;
import java.util.UUID;
public class GETuuid {
public static String[] chars = new String[] { "a", "b", "c", "d", "e", "f",
"g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s",
"t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I",
"J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
"W", "X", "Y", "Z" };
public static String generateShortUuid() {
StringBuffer shortBuffer = new StringBuffer();
String uuid = UUID.randomUUID().toString().replace("-", "");
for (int i = 0; i < 8; i++) {
String str = uuid.substring(i * 4, i * 4 + 4);
int x = Integer.parseInt(str, 16);
shortBuffer.append(chars[x % 0x3E]);
}
return shortBuffer.toString();
}
@Test
public void MN() {
for(int i = 0; i < 2000000000;i++){
System.out.println(generateShortUuid());
}
}
}
package CUT;
import CTY.CTYS;
import CTY.CUT;
import org.junit.Test;
import java.io.*;
import java.sql.SQLException;
import static CTY.GETuuid.generateShortUuid;
public class CUTYEST {
static int s=0;
String dir = "C:\\承认书\\";
@Test
public void MN() throws IOException {
recursiveTraversalFolder(dir);
}
public void recursiveTraversalFolder(String path) throws IOException {
File folder = new File(path);
if (folder.exists()) {
File[] fileArr = folder.listFiles();
if (null == fileArr || fileArr.length == 0) {
System.out.println("文件夹是空的 !");
return;
}
for (int i = 0; i < fileArr.length; ++i) {
if (fileArr[i].isDirectory()) {
this.recursiveTraversalFolder(fileArr[i].getAbsolutePath());
} else {
String fileName = fileArr[i].getName();
File parentPath = fileArr[i].getParentFile();
File newDir = new File(parentPath + "/" + fileName);
if(fileArr[i].getName().contains(".xls")
|| fileArr[i].getName().contains(".doc")
|| fileArr[i].getName().contains(".DOC")
|| fileArr[i].getName().contains(".pdf")
|| fileArr[i].getName().contains(".rar")
|| fileArr[i].getName().contains(".RAR")
|| fileArr[i].getName().contains(".PDF")
|| fileArr[i].getName().contains(".JPG")
|| fileArr[i].getName().contains(".jpg")
|| fileArr[i].getName().contains(".zip")
|| fileArr[i].getName().contains(".ZIP")
|| fileArr[i].getName().contains(".ppt")
|| fileArr[i].getName().contains(".txt")){
++s;
String uuid=generateShortUuid();
System.out.println(newDir+"<<<旧路径名字------------新名字>>>"+fileArr[i].getName().replaceAll("\\*","#").replaceAll("\\|","#").replaceAll("\\\\","#").replaceAll("/","#").substring(0,fileArr[i].getName().lastIndexOf("."))+"_"+uuid+fileArr[i].getName().substring(fileArr[i].getName().lastIndexOf("."))+"旧文件数量"+s);
CUT.CUT(newDir,fileArr[i].getName().replaceAll("\\*","#").replaceAll("\\|","#").replaceAll("\\\\","#").replaceAll("/","#").substring(0,fileArr[i].getName().lastIndexOf("."))+"_"+uuid+fileArr[i].getName().substring(fileArr[i].getName().lastIndexOf(".")),"D:\\test002\\");
}
}
}
} else {
System.out.println("文件不存在!");
}
}
}
下面是我的目录结构
可以直接运行test就行一共有两个类
CTY这个类是直接从本地文件夹遍历文件
遍历包含字符为cas的文件夹路径
如果包含就截取最后一个\后面的所有字符
然后根据所有字符从0开始截到9
然后调用数据库查询方法,把0-9参数传过去
如果能查到就按照数据库查出来的字段拼接
最后加上随机生成的uuid保证数据移动到同一个文件夹里不重复
最后根据当前文件截取当前文件.之后的所有字符拼接上去(这个为后缀)
查不到赋值为空
最后把新的文件移动到另外一个文件夹并且改名