Вопрос по c# – Создать файл, если файл не существует

57

Мне нужно получить код для чтения, если файл не существует, создать еще добавить. Прямо сейчас он читает, если он существует, создайте и добавьте. Вот код:

<code>if (File.Exists(path))
{
    using (StreamWriter sw = File.CreateText(path))
    {
</code>

Буду ли я это делать?

<code>if (! File.Exists(path))
{
    using (StreamWriter sw = File.CreateText(path))
    {
</code>

Редактировать:

<code>string path = txtFilePath.Text;

if (!File.Exists(path))
{
    using (StreamWriter sw = File.CreateText(path))
    {
        foreach (var line in employeeList.Items)
        {
            sw.WriteLine(((Employee)line).FirstName);
            sw.WriteLine(((Employee)line).LastName);
            sw.WriteLine(((Employee)line).JobTitle);
        }
    }
}
else
{
    StreamWriter sw = File.AppendText(path);

    foreach (var line in employeeList.Items)
    {
        sw.WriteLine(((Employee)line).FirstName);
        sw.WriteLine(((Employee)line).LastName);
        sw.WriteLine(((Employee)line).JobTitle);
    }
    sw.Close();
}
</code>

}

@ShadowWizard Так как это помеченное домашнее задание, OP может фактически указывать на показ условной логики. Yuck
File.AppendAllText - это делает именно то, что вам нужно в одной строке кода .. Shadow Wizard
@ Юк - домашнее задание, чтобы изобрести велосипед? Тьфу! ;) Shadow Wizard

Ваш Ответ

5   ответов
7

Да нужно отрицатьFile.Exists(path) если вы хотите проверить, если файлdoesn't существовать.

1

Например

    string rootPath = Path.GetPathRoot(Environment.GetFolderPath(Environment.SpecialFolder.System));
        rootPath += "MTN";
        if (!(File.Exists(rootPath)))
        {
            File.CreateText(rootPath);
        }
11

Вам даже не нужно делать проверку вручную, File.Open сделает это за вас. Пытаться:

using (StreamWriter sw = new StreamWriter(File.Open(path, System.IO.FileMode.Append))) 
{

Ref:http://msdn.microsoft.com/en-us/library/system.io.filemode.aspx

15

или же:

using(var fileStream = File.Open(path, FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
    using (StreamWriter sw = new StreamWriter(path, true))
    {
        //...
    }
}
Error: User Rate Limit Exceeded
86

Вы можете просто позвонить

using (StreamWriter w = File.AppendText("log.txt"))

Он создаст файл, если он не существует, и откроет файл для добавления.

Редактировать:

Этого достаточно:

string path = txtFilePath.Text;               
using(StreamWriter sw = File.AppendText(path))
{
  foreach (var line in employeeList.Items)                 
  {                    
    Employee e = (Employee)line; // unbox once
    sw.WriteLine(e.FirstName);                     
    sw.WriteLine(e.LastName);                     
    sw.WriteLine(e.JobTitle); 
  }                
}     

Но если вы настаиваете сначала на проверке, вы можете сделать что-то подобное, но я не вижу смысла.

string path = txtFilePath.Text;               


using (StreamWriter sw = (File.Exists(path)) ? File.AppendText(path) : File.CreateText(path))                 
{                      
    foreach (var line in employeeList.Items)                     
    {                         
      sw.WriteLine(((Employee)line).FirstName);                         
      sw.WriteLine(((Employee)line).LastName);                         
      sw.WriteLine(((Employee)line).JobTitle);                     
    }                  
} 

Кроме того, одна вещь, на которую следует обратить внимание в вашем коде, состоит в том, что вы делаете много ненужных распаковок. Если вам нужно использовать простую (не универсальную) коллекцию, такую какArrayList, затем распакуйте объект один раз и используйте ссылку.

Тем не менее, я предпочитаю использоватьList<> для моих коллекций:

public class EmployeeList : List<Employee>

Похожие вопросы