您好,登錄后才能下訂單哦!
為數不多的好用的代碼,遍歷文件夾獲取所有子文件名,"filespec"可用通配符“*?”。注意如果用相對路徑的話,獲取所有文件名后應再調用SetInitDir將初始目錄改為當前目錄,否則中間生成的文件都會放在之前的“InitDir”內。
C/C++遍歷文件夾感覺真是很不好用,建議還是使用C/C++做單任務處理,然后通過腳本語言實現遍歷比較合理。
CBrowseDir.h
#include <io.h> #include <stdlib.h> #include <direct.h> #include <iostream> #include <string> #include <vector> using namespace std; class CBrowseDir { protected: //存放初始目錄的絕對路徑,以'\'結尾 char m_szInitDir[_MAX_PATH]; public: //缺省構造器 CBrowseDir(); //設置初始目錄為dir,如果返回false,表示目錄不可用 bool SetInitDir(const char *dir); //開始遍歷初始目錄及其子目錄下由filespec指定類型的文件 //filespec可以使用通配符 * ?,不能包含路徑。 //如果返回false,表示遍歷過程被用戶中止 bool BeginBrowse(const char *filespec); vector<string> BeginBrowseFilenames(const char *filespec); protected: //遍歷目錄dir下由filespec指定的文件 //對于子目錄,采用迭代的方法 //如果返回false,表示中止遍歷文件 bool BrowseDir(const char *dir,const char *filespec); vector<string> GetDirFilenames(const char *dir,const char *filespec); //函數BrowseDir每找到一個文件,就調用ProcessFile //并把文件名作為參數傳遞過去 //如果返回false,表示中止遍歷文件 //用戶可以覆寫該函數,加入自己的處理代碼 virtual bool ProcessFile(const char *filename); //函數BrowseDir每進入一個目錄,就調用ProcessDir //并把正在處理的目錄名及上一級目錄名作為參數傳遞過去 //如果正在處理的是初始目錄,則parentdir=NULL //用戶可以覆寫該函數,加入自己的處理代碼 //比如用戶可以在這里統計子目錄的個數 virtual void ProcessDir(const char *currentdir,const char *parentdir); };
CBrowseDir.cpp
#include "CBrowseDir.h" CBrowseDir::CBrowseDir() { //用當前目錄初始化m_szInitDir getcwd(m_szInitDir,_MAX_PATH); //如果目錄的最后一個字母不是'\',則在最后加上一個'\' int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\') strcat(m_szInitDir,"\\"); } bool CBrowseDir::SetInitDir(const char *dir) { //先把dir轉換為絕對路徑 if (_fullpath(m_szInitDir,dir,_MAX_PATH) == NULL) return false; //判斷目錄是否存在 if (_chdir(m_szInitDir) != 0) return false; //如果目錄的最后一個字母不是'\',則在最后加上一個'\' int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\') strcat(m_szInitDir,"\\"); return true; } vector<string> CBrowseDir::BeginBrowseFilenames(const char *filespec) { ProcessDir(m_szInitDir,NULL); return GetDirFilenames(m_szInitDir,filespec); } bool CBrowseDir::BeginBrowse(const char *filespec) { ProcessDir(m_szInitDir,NULL); return BrowseDir(m_szInitDir,filespec); } bool CBrowseDir::BrowseDir(const char *dir,const char *filespec) { _chdir(dir); //首先查找dir中符合要求的文件 long hFile; _finddata_t fileinfo; if ((hFile=_findfirst(filespec,&fileinfo)) != -1) { do { //檢查是不是目錄 //如果不是,則進行處理 if (!(fileinfo.attrib & _A_SUBDIR)) { char filename[_MAX_PATH]; strcpy(filename,dir); strcat(filename,fileinfo.name); cout << filename << endl; if (!ProcessFile(filename)) return false; } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } //查找dir中的子目錄 //因為在處理dir中的文件時,派生類的ProcessFile有可能改變了 //當前目錄,因此還要重新設置當前目錄為dir。 //執行過_findfirst后,可能系統記錄下了相關信息,因此改變目錄 //對_findnext沒有影響。 _chdir(dir); if ((hFile=_findfirst("*.*",&fileinfo)) != -1) { do { //檢查是不是目錄 //如果是,再檢查是不是 . 或 .. //如果不是,進行迭代 if ((fileinfo.attrib & _A_SUBDIR)) { if (strcmp(fileinfo.name,".") != 0 && strcmp (fileinfo.name,"..") != 0) { char subdir[_MAX_PATH]; strcpy(subdir,dir); strcat(subdir,fileinfo.name); strcat(subdir,"\\"); ProcessDir(subdir,dir); if (!BrowseDir(subdir,filespec)) return false; } } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } return true; } vector<string> CBrowseDir::GetDirFilenames(const char *dir,const char *filespec) { _chdir(dir); vector<string>filename_vector; filename_vector.clear(); //首先查找dir中符合要求的文件 long hFile; _finddata_t fileinfo; if ((hFile=_findfirst(filespec,&fileinfo)) != -1) { do { //檢查是不是目錄 //如果不是,則進行處理 if (!(fileinfo.attrib & _A_SUBDIR)) { char filename[_MAX_PATH]; strcpy(filename,dir); strcat(filename,fileinfo.name); filename_vector.push_back(filename); } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } //查找dir中的子目錄 //因為在處理dir中的文件時,派生類的ProcessFile有可能改變了 //當前目錄,因此還要重新設置當前目錄為dir。 //執行過_findfirst后,可能系統記錄下了相關信息,因此改變目錄 //對_findnext沒有影響。 _chdir(dir); if ((hFile=_findfirst("*.*",&fileinfo)) != -1) { do { //檢查是不是目錄 //如果是,再檢查是不是 . 或 .. //如果不是,進行迭代 if ((fileinfo.attrib & _A_SUBDIR)) { if (strcmp(fileinfo.name,".") != 0 && strcmp (fileinfo.name,"..") != 0) { char subdir[_MAX_PATH]; strcpy(subdir,dir); strcat(subdir,fileinfo.name); strcat(subdir,"\\"); ProcessDir(subdir,dir); vector<string>tmp= GetDirFilenames(subdir,filespec); for (vector<string>::iterator it=tmp.begin();it<tmp.end();it++) { filename_vector.push_back(*it); } } } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } return filename_vector; } bool CBrowseDir::ProcessFile(const char *filename) { return true; } void CBrowseDir::ProcessDir(const char *currentdir,const char *parentdir) { }
實現方法二、
數據分多個文件存儲,讀取數據就需要對多個文件進行操作。首先就需要定位到文件的名字,之后再對文件進行相應的讀寫操作。多次涉及多文件的讀寫操作,現將這個實現總結一下,方便自己和他人使用。具體代碼如下:
#include "stdafx.h" #include <stdio.h> #include<iostream> #include<vector> #include <Windows.h> #include <fstream> #include <iterator> #include <string> using namespace std; #define MAX_PATH 1024 //最長路徑長度 /*---------------------------- * 功能 : 遞歸遍歷文件夾,找到其中包含的所有文件 *---------------------------- * 函數 : find * 訪問 : public * * 參數 : lpPath [in] 需遍歷的文件夾目錄 * 參數 : fileList [in] 以文件名稱的形式存儲遍歷后的文件 */ void find(char* lpPath,std::vector<const std::string> &fileList) { char szFind[MAX_PATH]; WIN32_FIND_DATA FindFileData; strcpy(szFind,lpPath); strcat(szFind,"\\*.*"); HANDLE hFind=::FindFirstFile(szFind,&FindFileData); if(INVALID_HANDLE_VALUE == hFind) return; while(true) { if(FindFileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) { if(FindFileData.cFileName[0]!='.') { char szFile[MAX_PATH]; strcpy(szFile,lpPath); strcat(szFile,"\\"); strcat(szFile,(char* )(FindFileData.cFileName)); find(szFile,fileList); } } else { //std::cout << FindFileData.cFileName << std::endl; fileList.push_back(FindFileData.cFileName); } if(!FindNextFile(hFind,&FindFileData)) break; } FindClose(hFind); } int main() { std::vector<const std::string> fileList;//定義一個存放結果文件名稱的鏈表 //遍歷一次結果的所有文件,獲取文件名列表 find("XXXX具體文件夾目錄",fileList);//之后可對文件列表中的文件進行相應的操作 //輸出文件夾下所有文件的名稱 for(int i = 0; i < fileList.size(); i++) { cout << fileList[i] << endl; } cout << "文件數目:" << fileList.size() << endl; return 0; }
測試了一下,目標文件夾下的文件名稱存在了fileList容器中,根據讀取的文件名稱,可對文件進行相應的操作,輸出結果如下所示:
c++ 遍歷目錄下文件方法三
function:遍歷目錄下所有文件,返回文件總數,子文件夾總數(修改一下可以獲得全部文件名等)。
#include "stdlib.h" #include "direct.h" #include "string.h" #include "io.h" #include "stdio.h" #include "iostream" using namespace std; class CBrowseDir { protected: //存放初始目錄的絕對路徑,以'\'結尾 char m_szInitDir[_MAX_PATH]; public: //缺省構造器 CBrowseDir(); //設置初始目錄為dir,如果返回false,表示目錄不可用 bool SetInitDir(const char *dir); //開始遍歷初始目錄及其子目錄下由filespec指定類型的文件 //filespec可以使用通配符 * ?,不能包含路徑。 //如果返回false,表示遍歷過程被用戶中止 bool BeginBrowse(const char *filespec); protected: //遍歷目錄dir下由filespec指定的文件 //對于子目錄,采用迭代的方法 //如果返回false,表示中止遍歷文件 bool BrowseDir(const char *dir,const char *filespec); //函數BrowseDir每找到一個文件,就調用ProcessFile //并把文件名作為參數傳遞過去 //如果返回false,表示中止遍歷文件 //用戶可以覆寫該函數,加入自己的處理代碼 virtual bool ProcessFile(const char *filename); //函數BrowseDir每進入一個目錄,就調用ProcessDir //并把正在處理的目錄名及上一級目錄名作為參數傳遞過去 //如果正在處理的是初始目錄,則parentdir=NULL //用戶可以覆寫該函數,加入自己的處理代碼 //比如用戶可以在這里統計子目錄的個數 virtual void ProcessDir(const char *currentdir,const char *parentdir); }; CBrowseDir::CBrowseDir() { //用當前目錄初始化m_szInitDir getcwd(m_szInitDir,_MAX_PATH); //如果目錄的最后一個字母不是'\',則在最后加上一個'\' int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\') strcat(m_szInitDir,"\\"); } bool CBrowseDir::SetInitDir(const char *dir) { //先把dir轉換為絕對路徑 if (_fullpath(m_szInitDir,dir,_MAX_PATH) == NULL) return false; //判斷目錄是否存在 if (_chdir(m_szInitDir) != 0) return false; //如果目錄的最后一個字母不是'\',則在最后加上一個'\' int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\') strcat(m_szInitDir,"\\"); return true; } bool CBrowseDir::BeginBrowse(const char *filespec) { ProcessDir(m_szInitDir,NULL); return BrowseDir(m_szInitDir,filespec); } bool CBrowseDir::BrowseDir(const char *dir,const char *filespec) { _chdir(dir); //首先查找dir中符合要求的文件 long hFile; _finddata_t fileinfo; if ((hFile=_findfirst(filespec,&fileinfo)) != -1) { do { //檢查是不是目錄 //如果不是,則進行處理 if (!(fileinfo.attrib & _A_SUBDIR)) { char filename[_MAX_PATH]; strcpy(filename,dir); strcat(filename,fileinfo.name); cout << filename << endl; if (!ProcessFile(filename)) return false; } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } //查找dir中的子目錄 //因為在處理dir中的文件時,派生類的ProcessFile有可能改變了 //當前目錄,因此還要重新設置當前目錄為dir。 //執行過_findfirst后,可能系統記錄下了相關信息,因此改變目錄 //對_findnext沒有影響。 _chdir(dir); if ((hFile=_findfirst("*.*",&fileinfo)) != -1) { do { //檢查是不是目錄 //如果是,再檢查是不是 . 或 .. //如果不是,進行迭代 if ((fileinfo.attrib & _A_SUBDIR)) { if (strcmp(fileinfo.name,".") != 0 && strcmp (fileinfo.name,"..") != 0) { char subdir[_MAX_PATH]; strcpy(subdir,dir); strcat(subdir,fileinfo.name); strcat(subdir,"\\"); ProcessDir(subdir,dir); if (!BrowseDir(subdir,filespec)) return false; } } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } return true; } bool CBrowseDir::ProcessFile(const char *filename) { return true; } void CBrowseDir::ProcessDir(const char *currentdir,const char *parentdir) { } //從CBrowseDir派生出的子類,用來統計目錄中的文件及子目錄個數 class CStatDir:public CBrowseDir { protected: int m_nFileCount; //保存文件個數 int m_nSubdirCount; //保存子目錄個數 public: //缺省構造器 CStatDir() { //初始化數據成員m_nFileCount和m_nSubdirCount m_nFileCount=m_nSubdirCount=0; } //返回文件個數 int GetFileCount() { return m_nFileCount; } //返回子目錄個數 int GetSubdirCount() { //因為進入初始目錄時,也會調用函數ProcessDir, //所以減1后才是真正的子目錄個數。 return m_nSubdirCount-1; } protected: //覆寫虛函數ProcessFile,每調用一次,文件個數加1 virtual bool ProcessFile(const char *filename) { m_nFileCount++; return CBrowseDir::ProcessFile(filename); } //覆寫虛函數ProcessDir,每調用一次,子目錄個數加1 virtual void ProcessDir (const char *currentdir,const char *parentdir) { m_nSubdirCount++; CBrowseDir::ProcessDir(currentdir,parentdir); } }; void main() { //獲取目錄名 char buf[256]; printf("請輸入要統計的目錄名:"); gets(buf); //構造類對象 CStatDir statdir; //設置要遍歷的目錄 if (!statdir.SetInitDir(buf)) { puts("目錄不存在。"); return; } //開始遍歷 statdir.BeginBrowse("*.*"); printf("文件總數: %d\n子目錄總數:%d\n",statdir.GetFileCount(),statdir.GetSubdirCount()); }
已在windows上驗證有效。
下面我加了BeginBrowseFilenames函數,以vector<char*>形式返回目錄中所有文件名。
#include "stdlib.h" #include "direct.h" #include "string.h" #include "string" #include "io.h" #include "stdio.h" #include <vector> #include "iostream" using namespace std; class CBrowseDir { protected: //存放初始目錄的絕對路徑,以'\'結尾 char m_szInitDir[_MAX_PATH]; public: //缺省構造器 CBrowseDir(); //設置初始目錄為dir,如果返回false,表示目錄不可用 bool SetInitDir(const char *dir); //開始遍歷初始目錄及其子目錄下由filespec指定類型的文件 //filespec可以使用通配符 * ?,不能包含路徑。 //如果返回false,表示遍歷過程被用戶中止 bool BeginBrowse(const char *filespec); vector<string> BeginBrowseFilenames(const char *filespec); protected: //遍歷目錄dir下由filespec指定的文件 //對于子目錄,采用迭代的方法 //如果返回false,表示中止遍歷文件 bool BrowseDir(const char *dir,const char *filespec); vector<string> GetDirFilenames(const char *dir,const char *filespec); //函數BrowseDir每找到一個文件,就調用ProcessFile //并把文件名作為參數傳遞過去 //如果返回false,表示中止遍歷文件 //用戶可以覆寫該函數,加入自己的處理代碼 virtual bool ProcessFile(const char *filename); //函數BrowseDir每進入一個目錄,就調用ProcessDir //并把正在處理的目錄名及上一級目錄名作為參數傳遞過去 //如果正在處理的是初始目錄,則parentdir=NULL //用戶可以覆寫該函數,加入自己的處理代碼 //比如用戶可以在這里統計子目錄的個數 virtual void ProcessDir(const char *currentdir,const char *parentdir); }; CBrowseDir::CBrowseDir() { //用當前目錄初始化m_szInitDir getcwd(m_szInitDir,_MAX_PATH); //如果目錄的最后一個字母不是'\',則在最后加上一個'\' int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\') strcat(m_szInitDir,"\\"); } bool CBrowseDir::SetInitDir(const char *dir) { //先把dir轉換為絕對路徑 if (_fullpath(m_szInitDir,dir,_MAX_PATH) == NULL) return false; //判斷目錄是否存在 if (_chdir(m_szInitDir) != 0) return false; //如果目錄的最后一個字母不是'\',則在最后加上一個'\' int len=strlen(m_szInitDir); if (m_szInitDir[len-1] != '\\') strcat(m_szInitDir,"\\"); return true; } vector<string> CBrowseDir::BeginBrowseFilenames(const char *filespec) { ProcessDir(m_szInitDir,NULL); return GetDirFilenames(m_szInitDir,filespec); } bool CBrowseDir::BeginBrowse(const char *filespec) { ProcessDir(m_szInitDir,NULL); return BrowseDir(m_szInitDir,filespec); } bool CBrowseDir::BrowseDir(const char *dir,const char *filespec) { _chdir(dir); //首先查找dir中符合要求的文件 long hFile; _finddata_t fileinfo; if ((hFile=_findfirst(filespec,&fileinfo)) != -1) { do { //檢查是不是目錄 //如果不是,則進行處理 if (!(fileinfo.attrib & _A_SUBDIR)) { char filename[_MAX_PATH]; strcpy(filename,dir); strcat(filename,fileinfo.name); cout << filename << endl; if (!ProcessFile(filename)) return false; } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } //查找dir中的子目錄 //因為在處理dir中的文件時,派生類的ProcessFile有可能改變了 //當前目錄,因此還要重新設置當前目錄為dir。 //執行過_findfirst后,可能系統記錄下了相關信息,因此改變目錄 //對_findnext沒有影響。 _chdir(dir); if ((hFile=_findfirst("*.*",&fileinfo)) != -1) { do { //檢查是不是目錄 //如果是,再檢查是不是 . 或 .. //如果不是,進行迭代 if ((fileinfo.attrib & _A_SUBDIR)) { if (strcmp(fileinfo.name,".") != 0 && strcmp (fileinfo.name,"..") != 0) { char subdir[_MAX_PATH]; strcpy(subdir,dir); strcat(subdir,fileinfo.name); strcat(subdir,"\\"); ProcessDir(subdir,dir); if (!BrowseDir(subdir,filespec)) return false; } } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } return true; } vector<string> CBrowseDir::GetDirFilenames(const char *dir,const char *filespec) { _chdir(dir); vector<string>filename_vector; filename_vector.clear(); //首先查找dir中符合要求的文件 long hFile; _finddata_t fileinfo; if ((hFile=_findfirst(filespec,&fileinfo)) != -1) { do { //檢查是不是目錄 //如果不是,則進行處理 if (!(fileinfo.attrib & _A_SUBDIR)) { char filename[_MAX_PATH]; strcpy(filename,dir); strcat(filename,fileinfo.name); filename_vector.push_back(filename); } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } //查找dir中的子目錄 //因為在處理dir中的文件時,派生類的ProcessFile有可能改變了 //當前目錄,因此還要重新設置當前目錄為dir。 //執行過_findfirst后,可能系統記錄下了相關信息,因此改變目錄 //對_findnext沒有影響。 _chdir(dir); if ((hFile=_findfirst("*.*",&fileinfo)) != -1) { do { //檢查是不是目錄 //如果是,再檢查是不是 . 或 .. //如果不是,進行迭代 if ((fileinfo.attrib & _A_SUBDIR)) { if (strcmp(fileinfo.name,".") != 0 && strcmp (fileinfo.name,"..") != 0) { char subdir[_MAX_PATH]; strcpy(subdir,dir); strcat(subdir,fileinfo.name); strcat(subdir,"\\"); ProcessDir(subdir,dir); vector<string>tmp= GetDirFilenames(subdir,filespec); for (vector<string>::iterator it=tmp.begin();it<tmp.end();it++) { filename_vector.push_back(*it); } } } } while (_findnext(hFile,&fileinfo) == 0); _findclose(hFile); } return filename_vector; } bool CBrowseDir::ProcessFile(const char *filename) { return true; } void CBrowseDir::ProcessDir(const char *currentdir,const char *parentdir) { } //從CBrowseDir派生出的子類,用來統計目錄中的文件及子目錄個數 class CStatDir:public CBrowseDir { protected: int m_nFileCount; //保存文件個數 int m_nSubdirCount; //保存子目錄個數 public: //缺省構造器 CStatDir() { //初始化數據成員m_nFileCount和m_nSubdirCount m_nFileCount=m_nSubdirCount=0; } //返回文件個數 int GetFileCount() { return m_nFileCount; } //返回子目錄個數 int GetSubdirCount() { //因為進入初始目錄時,也會調用函數ProcessDir, //所以減1后才是真正的子目錄個數。 return m_nSubdirCount-1; } protected: //覆寫虛函數ProcessFile,每調用一次,文件個數加1 virtual bool ProcessFile(const char *filename) { m_nFileCount++; return CBrowseDir::ProcessFile(filename); } //覆寫虛函數ProcessDir,每調用一次,子目錄個數加1 virtual void ProcessDir (const char *currentdir,const char *parentdir) { m_nSubdirCount++; CBrowseDir::ProcessDir(currentdir,parentdir); } }; void main() { //獲取目錄名 char buf[256]; printf("請輸入要統計的目錄名:"); gets(buf); //構造類對象 CStatDir statdir; //設置要遍歷的目錄 if (!statdir.SetInitDir(buf)) { puts("目錄不存在。"); return; } //開始遍歷 vector<string>file_vec = statdir.BeginBrowseFilenames("*.*"); for(vector<string>::const_iterator it = file_vec.begin(); it < file_vec.end(); ++it) std::cout<<*it<<std::endl; printf("文件總數: %d\n",file_vec.size()); system("pause"); }
方法四、C++讀取某個文件夾下面的子文件夾及其所有文件
下面是輸出當前目錄下的所有文件夾以及文件的絕對路徑(當然也可以是相對路徑,由輸入的路徑決定),下面的函數接口可以改裝為單輸出文件或者文件夾的接口,這是一個大方面的總接口。
#include <fstream> #include <iostream> #include <string> #include <sstream> #include <vector> using namespace std; void getAllFiles(string path, vector<string>& files) { //文件句柄 long hFile = 0; //文件信息 struct _finddata_t fileinfo; //很少用的文件信息讀取結構 string p; //string類很有意思的一個賦值函數:assign(),有很多重載版本 if ((hFile = _findfirst(p.assign(path).append("\\*").c_str(), &fileinfo)) != -1) { do { if ((fileinfo.attrib & _A_SUBDIR)) //判斷是否為文件夾 { if (strcmp(fileinfo.name, ".") != 0 && strcmp(fileinfo.name, "..") != 0) { files.push_back(p.assign(path).append("/").append(fileinfo.name));//保存文件夾名字 getAllFiles(p.assign(path).append("/").append(fileinfo.name), files);//遞歸當前文件夾 } } else //文件處理 { files.push_back(p.assign(path).append("/").append(fileinfo.name));//文件名 } } while (_findnext(hFile, &fileinfo) == 0); //尋找下一個,成功返回0,否則-1 _findclose(hFile); } } //測試 void main() { string DATA_DIR = "D:/CoderMaker/data_sets/lfw"; vector<string> files; //測試 char * DistAll = "AllFiles.txt"; getAllFiles(DATA_DIR, files);//所有文件與文件夾的路徑都輸出 ofstream ofn(DistAll); //輸出文件流 int size = files.size(); int FaiNum = 0; ofn << size << endl; for (int i = 0; i<size; i++) { ofn << files[i] << endl; } ofn.close(); return 0; }
測試結果
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。