У меня есть данные, поступающие из поля nvarchar базы данных сервера SQL через EF3.5.Эта строка используется для создания имени файла и требует удаления недопустимых символов и пробует следующие опции, но ни один из них не работает.Пожалуйста, предложите, почему это такая понятная загадка?Я делаю что-то не так?
Я рассмотрел почти все связанные вопросы на этом сайте ... и теперь публикую сводный вопрос по всем предложениям / ответам по другим аналогичным вопросам.
UPD: проблема не связана. Все эти варианты работают.Так что публикуем его в вики сообщества.
public static string CleanFileName1(string filename)
{
string file = filename;
file = string.Concat(file.Split(System.IO.Path.GetInvalidFileNameChars(), StringSplitOptions.RemoveEmptyEntries));
if (file.Length > 250)
{
file = file.Substring(0, 250);
}
return file;
}
public static string CleanFileName2(string filename)
{
var builder = new StringBuilder();
var invalid = System.IO.Path.GetInvalidFileNameChars();
foreach (var cur in filename)
{
if (!invalid.Contains(cur))
{
builder.Append(cur);
}
}
return builder.ToString();
}
public static string CleanFileName3(string filename)
{
string regexSearch = string.Format("{0}{1}",
new string(System.IO.Path.GetInvalidFileNameChars()),
new string(System.IO.Path.GetInvalidPathChars()));
Regex r = new Regex(string.Format("[{0}]", Regex.Escape(regexSearch)));
string file = r.Replace(filename, "");
return file;
}
public static string CleanFileName4(string filename)
{
return new String(filename.Except(System.IO.Path.GetInvalidFileNameChars()).ToArray());
}
public static string CleanFileName5(string filename)
{
string file = filename;
foreach (char c in System.IO.Path.GetInvalidFileNameChars())
{
file = file.Replace(c, '_');
}
return file;
}