Файл поступает через EDI как. Мне нужно изменить его на .txt и перенести его в другую папку. Все работает отлично для примерно 3-5 файлов, а затем начинает бросать исключения. Я пробовал обращаться с ними, но это не решает проблему. Я также получаю спорадические (filename не могут быть нулевые) исключения. Я просто не могу понять это.FileSystemWatcher работает 3-5 раз, прежде чем выбрасывать исключения - C#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.IO;
using System.Diagnostics;
using System.Threading;
using System.Windows.Forms;
using System.Security.Permissions;
namespace FileConverterService
{
class ConverterService
{
//Configure watcher & input
private FileSystemWatcher _watcher;
public bool Start()
{
_watcher = new FileSystemWatcher(@"C:\FTP_base\temp", "*.today");
_watcher.Created += new FileSystemEventHandler(FileCreated);
_watcher.IncludeSubdirectories = false;
_watcher.EnableRaisingEvents = true;
return true;
}
//Configure output creation and append file name to include .txt extension
[PermissionSet(SecurityAction.Demand, Name = "FullTrust")]
private void FileCreated(object sender, FileSystemEventArgs e)
{
try
{
string dateTime = DateTime.Now.ToString("yyyyMMddHHmmssfff");
string content = File.ReadAllText(e.FullPath);
string upperContent = content.ToUpperInvariant();
var dir = Path.GetDirectoryName(e.FullPath);
var convertedFileName = Path.GetFileName(e.FullPath) + dateTime + ".txt";
var convertedPath = Path.Combine(dir, convertedFileName);
File.WriteAllText(convertedPath, upperContent);
}
catch (IOException f)
{
if (f is IOException)
{
MessageBox.Show("Exception Caught"); //was just testing
}
}
MoveConvert();
}
//Move converted file to EDI processing folder
public static void MoveConvert()
{
try {
string dateTime = DateTime.Now.ToString("yyyyMMddHHmmssfff");
string rootFolderPath = @"C:\FTP_base\temp\";
string moveTo = @"C:\FTP_base\INbound\inbound_" + dateTime + ".txt";
//string moveTo = @"F:\FTP_base\Office Depot\INbound\inbound_" + dateTime + ".txt";
string filesToMove = @"*.txt"; // Only move .txt
string myfile2 = System.IO.Directory.GetFiles(rootFolderPath, filesToMove).FirstOrDefault();
string fileToMove = myfile2;
//moving file
File.Move(fileToMove, moveTo);
MoveOriginal();
}
catch (IOException e)
{
if (e is IOException)
{
MessageBox.Show("File already exists."); //was just testing
}
}
}
public static void MoveOriginal()
{
try {
string dateTime = DateTime.Now.ToString("yyyyMMddHHmmssfff");
string rootFolderPath2 = @"C:\FTP_base\temp\";
string moveTo2 = @"C:\FTP_base\archive\archive_" + dateTime + ".archive";
//string moveTo2 = @"F:\Xcelerator_EDI\OfficeDepot\DataFiles\Inbound\Archive2\archive_" + dateTime + ".archive";
string filesToMove2 = @"*.today"; // Only move .today
string myfile = System.IO.Directory.GetFiles(rootFolderPath2, filesToMove2).FirstOrDefault();
//foreach (string file in fileList)
string fileToMove2 = myfile;
//moving file
File.Move(fileToMove2, moveTo2);
}
catch (IOException e)
{
if (e is IOException)
{
MessageBox.Show("IO Exception Occurred"); //was just testing
}
}
}
//Stop Service control
public bool Stop()
{
_watcher.Dispose();
return true;
}
}
}
Иногда он работает только один раз, прежде чем бросать исключения, иногда делает 5 или 6 в ряд перед бросанием. Очень странно. – Derek
, в какой строке это происходит? –
'FileSystemWatcher', как известно, трудно использовать, поскольку в нем много состояний ошибок. Если вы открыты для использования Rx и не против кода, созданного другой компанией-исполнителем, у меня есть [обертка] (https://idcomlog.codeplex.com/SourceControl/latest#IdComLog.Reactive/FileSystem.cs) (также на [NuGet] (https://www.nuget.org/packages/IdComLog.Reactive/)) Я создал, чтобы сделать его намного более надежным. –