根据创建日期对文件进行排序?
Sort files according to creation date?
第一个问题解决了。文件整理得很好
for (int i = 0; i < allFiles.GetSize(); i++)
{
box1.AddString(allFiles[i]);
}
vector<file> files;
vector<tstring> vec;
vec.insert(vec.begin(), &allFiles[0], &allFiles[allFiles.GetSize() - 1] + 1);
transform(vec.begin(), vec.end(),back_inserter(files),[](wstring const &fname)
{
WIN32_FIND_DATA d;
HANDLE h = FindFirstFile(fname.c_str(), &d);
FindClose(h);
return d;
}
);
sort(files.begin(), files.end());
CStringArray sortFiles;
files.insert(files.begin(), &sortFiles[0], &sortFiles[sortFiles.GetSize() - 1] + 1);
现在的问题是我如何在 CStringArray 中保存排序文件。 Last Statement 显示错误看到评论了吗?
我会:
- 创建一个类型来保存文件名和时间戳。
- 使用
FindFirstFile
获取您关心的每个文件的时间戳。
- 创建一个 name/timestamp 对象并将其存储到向量中。
- 为该文件调用
FindClose
。
- 为每个输入文件名从 2 开始重复。
- 根据时间戳对向量进行排序。
- 大概用Windows'
CompareFileTime
.
- 显示结果。
因此,一种可能的实现方式可能如下所示:
#include <iostream>
#include <Windows.h>
#include <algorithm>
#include <string>
#include <vector>
#include <iomanip>
class file {
std::string name;
FILETIME time;
public:
bool operator<(file const &other) const {
return CompareFileTime(&time, &other.time) == 1;
}
friend std::ostream &operator<<(std::ostream &os, file const &f) {
SYSTEMTIME st;
FileTimeToSystemTime(&f.time, &st);
return os << std::setw(20) << f.name << "\t" << st.wHour << ":" << st.wMinute << ":" << st.wSecond << " " << st.wYear << "/" << st.wMonth << "/" << st.wDay;
}
file(WIN32_FIND_DATA const &d) : name(d.cFileName), time(d.ftCreationTime) {}
};
int main(){
std::vector<std::string> inputs{ "a.txt", "b.txt" };
std::vector<file> files;
std::transform(inputs.begin(), inputs.end(),
std::back_inserter(files),
[](std::string const &fname) {
WIN32_FIND_DATA d;
HANDLE h = FindFirstFile(fname.c_str(), &d);
FindClose(h);
return d;
}
);
std::sort(files.begin(), files.end());
std::copy(files.begin(),files.end(),
std::ostream_iterator<file>(std::cout, "\n"));
}
要处理文件名的 "wide" (Unicode) 字符串,您需要(稍微)修改它,使其看起来像这样:
#include <iostream>
#include <Windows.h>
#include <algorithm>
#include <string>
#include <vector>
#include <iomanip>
class file {
std::wstring name;
FILETIME time;
public:
bool operator<(file const &other) const {
return CompareFileTime(&time, &other.time) == 1;
}
friend std::wostream &operator<<(std::wostream &os, file const &f) {
SYSTEMTIME st;
FileTimeToSystemTime(&f.time, &st);
return os << std::setw(20) << f.name << L"\t" << st.wHour << L":" << st.wMinute << L":" << st.wSecond << L" " << st.wYear << L"/" << st.wMonth << L"/" << st.wDay;
}
file(WIN32_FIND_DATA const &d) : name(d.cFileName), time(d.ftCreationTime) {}
};
int main(){
std::vector<std::wstring> inputs{ L"a.txt", L"b.txt" };
std::vector<file> files;
std::transform(inputs.begin(), inputs.end(),
std::back_inserter(files),
[](std::wstring const &fname) {
WIN32_FIND_DATA d;
HANDLE h = FindFirstFile(fname.c_str(), &d);
FindClose(h);
return d;
}
);
std::sort(files.begin(), files.end());
for (auto const &f : files)
std::wcout << f << L"\n";
}
然后当你构建它时,你需要通过在编译时定义 UNICODE
来告诉编译器你想要 Windows 函数的 Unicode 版本:
cl -DUNICODE files.cpp
根据创建日期或上次写入日期对文件进行排序的简单方法是将文件存储到映射中,其中键是日期,值是文件名。地图会为您排序..我的代码示例如下..
BOOL GetLastWriteTime(FILETIME ftWrite, LPWSTR lpszString, DWORD dwSize)
{
DWORD dwRet;
SYSTEMTIME st, stLocal;
// Convert the last-write time to local time.
FileTimeToSystemTime(&ftWrite, &st);
SystemTimeToTzSpecificLocalTime(NULL, &st, &stLocal);
// Build a string showing the date and time.
dwRet = StringCchPrintf(lpszString, dwSize,
TEXT("%02d%02d%d%02d%02d%02d%04d"),
stLocal.wMonth, stLocal.wDay, stLocal.wYear,
stLocal.wHour, stLocal.wMinute, stLocal.wSecond, stLocal.wMilliseconds);
if( S_OK == dwRet )
return TRUE;
else return FALSE;
}
int _tmain(int argc, _TCHAR* argv[])
{
std::map<wstring, wstring> first;
wstring directory = L"D:\SourceCode\FilesTemp\*";
std::wstring name;
WCHAR szBuf[MAX_PATH];
WIN32_FIND_DATA d;
HANDLE hFindFile = FindFirstFile ( directory.c_str(), &d );
if (hFindFile == INVALID_HANDLE_VALUE)
{
DWORD dwLastError = ::GetLastError();
if( dwLastError != ERROR_NO_MORE_FILES &&
dwLastError != ERROR_FILE_NOT_FOUND)
{
return FALSE;
}
// No files found
return TRUE;
}
do
{
if( d.cFileName[0] && _tcscmp( d.cFileName, _T( "." )) != 0 &&_tcscmp( d.cFileName, _T( ".." )) != 0 )
{
name = d.cFileName;
if(GetLastWriteTime( d.ftLastWriteTime, szBuf, MAX_PATH ))
{
_tprintf(TEXT("Last write time is: %s\n"), szBuf);
first[szBuf] = name;
}
}
}while (FindNextFile ( hFindFile, &d ));
return 0;
}
第一个问题解决了。文件整理得很好
for (int i = 0; i < allFiles.GetSize(); i++)
{
box1.AddString(allFiles[i]);
}
vector<file> files;
vector<tstring> vec;
vec.insert(vec.begin(), &allFiles[0], &allFiles[allFiles.GetSize() - 1] + 1);
transform(vec.begin(), vec.end(),back_inserter(files),[](wstring const &fname)
{
WIN32_FIND_DATA d;
HANDLE h = FindFirstFile(fname.c_str(), &d);
FindClose(h);
return d;
}
);
sort(files.begin(), files.end());
CStringArray sortFiles;
files.insert(files.begin(), &sortFiles[0], &sortFiles[sortFiles.GetSize() - 1] + 1);
现在的问题是我如何在 CStringArray 中保存排序文件。 Last Statement 显示错误看到评论了吗?
我会:
- 创建一个类型来保存文件名和时间戳。
- 使用
FindFirstFile
获取您关心的每个文件的时间戳。 - 创建一个 name/timestamp 对象并将其存储到向量中。
- 为该文件调用
FindClose
。 - 为每个输入文件名从 2 开始重复。
- 根据时间戳对向量进行排序。
- 大概用Windows'
CompareFileTime
.
- 大概用Windows'
- 显示结果。
因此,一种可能的实现方式可能如下所示:
#include <iostream>
#include <Windows.h>
#include <algorithm>
#include <string>
#include <vector>
#include <iomanip>
class file {
std::string name;
FILETIME time;
public:
bool operator<(file const &other) const {
return CompareFileTime(&time, &other.time) == 1;
}
friend std::ostream &operator<<(std::ostream &os, file const &f) {
SYSTEMTIME st;
FileTimeToSystemTime(&f.time, &st);
return os << std::setw(20) << f.name << "\t" << st.wHour << ":" << st.wMinute << ":" << st.wSecond << " " << st.wYear << "/" << st.wMonth << "/" << st.wDay;
}
file(WIN32_FIND_DATA const &d) : name(d.cFileName), time(d.ftCreationTime) {}
};
int main(){
std::vector<std::string> inputs{ "a.txt", "b.txt" };
std::vector<file> files;
std::transform(inputs.begin(), inputs.end(),
std::back_inserter(files),
[](std::string const &fname) {
WIN32_FIND_DATA d;
HANDLE h = FindFirstFile(fname.c_str(), &d);
FindClose(h);
return d;
}
);
std::sort(files.begin(), files.end());
std::copy(files.begin(),files.end(),
std::ostream_iterator<file>(std::cout, "\n"));
}
要处理文件名的 "wide" (Unicode) 字符串,您需要(稍微)修改它,使其看起来像这样:
#include <iostream>
#include <Windows.h>
#include <algorithm>
#include <string>
#include <vector>
#include <iomanip>
class file {
std::wstring name;
FILETIME time;
public:
bool operator<(file const &other) const {
return CompareFileTime(&time, &other.time) == 1;
}
friend std::wostream &operator<<(std::wostream &os, file const &f) {
SYSTEMTIME st;
FileTimeToSystemTime(&f.time, &st);
return os << std::setw(20) << f.name << L"\t" << st.wHour << L":" << st.wMinute << L":" << st.wSecond << L" " << st.wYear << L"/" << st.wMonth << L"/" << st.wDay;
}
file(WIN32_FIND_DATA const &d) : name(d.cFileName), time(d.ftCreationTime) {}
};
int main(){
std::vector<std::wstring> inputs{ L"a.txt", L"b.txt" };
std::vector<file> files;
std::transform(inputs.begin(), inputs.end(),
std::back_inserter(files),
[](std::wstring const &fname) {
WIN32_FIND_DATA d;
HANDLE h = FindFirstFile(fname.c_str(), &d);
FindClose(h);
return d;
}
);
std::sort(files.begin(), files.end());
for (auto const &f : files)
std::wcout << f << L"\n";
}
然后当你构建它时,你需要通过在编译时定义 UNICODE
来告诉编译器你想要 Windows 函数的 Unicode 版本:
cl -DUNICODE files.cpp
根据创建日期或上次写入日期对文件进行排序的简单方法是将文件存储到映射中,其中键是日期,值是文件名。地图会为您排序..我的代码示例如下..
BOOL GetLastWriteTime(FILETIME ftWrite, LPWSTR lpszString, DWORD dwSize)
{
DWORD dwRet;
SYSTEMTIME st, stLocal;
// Convert the last-write time to local time.
FileTimeToSystemTime(&ftWrite, &st);
SystemTimeToTzSpecificLocalTime(NULL, &st, &stLocal);
// Build a string showing the date and time.
dwRet = StringCchPrintf(lpszString, dwSize,
TEXT("%02d%02d%d%02d%02d%02d%04d"),
stLocal.wMonth, stLocal.wDay, stLocal.wYear,
stLocal.wHour, stLocal.wMinute, stLocal.wSecond, stLocal.wMilliseconds);
if( S_OK == dwRet )
return TRUE;
else return FALSE;
}
int _tmain(int argc, _TCHAR* argv[])
{
std::map<wstring, wstring> first;
wstring directory = L"D:\SourceCode\FilesTemp\*";
std::wstring name;
WCHAR szBuf[MAX_PATH];
WIN32_FIND_DATA d;
HANDLE hFindFile = FindFirstFile ( directory.c_str(), &d );
if (hFindFile == INVALID_HANDLE_VALUE)
{
DWORD dwLastError = ::GetLastError();
if( dwLastError != ERROR_NO_MORE_FILES &&
dwLastError != ERROR_FILE_NOT_FOUND)
{
return FALSE;
}
// No files found
return TRUE;
}
do
{
if( d.cFileName[0] && _tcscmp( d.cFileName, _T( "." )) != 0 &&_tcscmp( d.cFileName, _T( ".." )) != 0 )
{
name = d.cFileName;
if(GetLastWriteTime( d.ftLastWriteTime, szBuf, MAX_PATH ))
{
_tprintf(TEXT("Last write time is: %s\n"), szBuf);
first[szBuf] = name;
}
}
}while (FindNextFile ( hFindFile, &d ));
return 0;
}