0
char    tempFilename[256];
wchar_t filename[512];

fprintf(stdout, "Please enter file name/path: \n");
getchar();
fgets(tempFilename, 255, stdin);

MultiByteToWideChar(CP_ACP, 0, tempFilename, -1, filename, strlen(tempFilename)*2);

if((hReadFile = CreateFile(filename, GENERIC_READ , 0, 0, OPEN_EXISTING, 0, 0)) == INVALID_HANDLE_VALUE)
{
    fprintf(stdout, "File could not be opened, make sure name is under 256 chars. Error Code - %d.\n", GetLastError());
    return (0);
}

我检查了 MultiByteToWideChar() 是否成功。

事实上,我也尝试过像 C:\users\user_name\desktop\test.txt 这样的路径,而不是 C:\users\user_name\desktop\test.txt

我使用以下将 \ 转换为 \\

while(temp < len )
{
    filename1[cntr1] = tempFilename[temp];
    cntr1 += 1;
    if(tempFilename[temp] == '\\')
    {
        filename1[cntr1] = '\\';
        cntr1 += 1;
    }
    temp += 1;
}

这一直有效到 \ 到 \\。我哪里错了..?

4

1 回答 1

4

filename在您尝试使用它之前打印出来。十分之九,像这样的简单调试输出将向您显示确切的问题。

并用分隔符打印出来,这样你就可以看到那里是否有换行符:

printf ("[%s]\n", filename);

(或等效方法,例如使用wprintf)。

如果有换行符,您将看到:

[myfile.txt
]

代替:

[myfile.txt]

如果你得到一个字符串,你想去掉换行符,你可以使用类似的东西:

int slen = strlen (filename);
if ((slen > 0) && (filename[slen-1] == '\n'))
    filename[slen-1] = '\0';

(再次,或等效,例如使用wcslen)。

另一方面,如果输入来自用户,则不需要\替换为。\\只有 C 源代码本身需要转义。

而且,最后一件事,我不完全确定你getchar()之前打电话的原因fgets()——你可能会丢失你输入的任何内容的第一个字符。

于 2013-09-10T07:32:11.033 回答