FileAccess.cs 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace crusherScanner
  7. {
  8. /// <summary>
  9. /// File access for ML jobs usinf CSV parse.
  10. /// </summary>
  11. internal class FileAccess
  12. {
  13. public static HashSet<Samples> GetOreDefData(HashSet<Samples> samples,string barcode)
  14. {
  15. string[] DataDirs = new string[2] { Properties.Settings.Default.OreDefWorkFile, Properties.Settings.Default.OreDefInFile };
  16. try
  17. {
  18. foreach (var DataDir in DataDirs)
  19. {
  20. if (Directory.Exists(DataDir))
  21. {
  22. var jobFiles = Directory.EnumerateFiles(DataDir, "ML??????.csv", SearchOption.TopDirectoryOnly);
  23. foreach (var jobFile in jobFiles)
  24. {
  25. bool sampleFound;
  26. (samples, sampleFound) = ReadCSV(barcode, jobFile, samples);
  27. if (sampleFound)
  28. {
  29. return samples;
  30. }
  31. }
  32. }
  33. }
  34. }
  35. catch (Exception ex)
  36. {
  37. MessageBox.Show("An error occurred." + Environment.NewLine + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  38. }
  39. return samples;
  40. }
  41. private static (HashSet<Samples>,bool) ReadCSV(string barcode, string CsvFile, HashSet<Samples> samples)
  42. {
  43. bool BarcodeFound = false;
  44. string[] RawSampleData = new string[1] { "" };
  45. string[] lines = File.ReadAllLines(CsvFile);
  46. foreach (var line in lines)
  47. {
  48. if (line.Contains('\u002C'))
  49. {
  50. RawSampleData = line.Split('\u002C');
  51. }
  52. if (RawSampleData.Length == 9)
  53. {
  54. Samples sample = new();
  55. if (RawSampleData[0] == barcode)
  56. {
  57. BarcodeFound = true;
  58. }
  59. if (RawSampleData[0] != "SAMPLEID")
  60. {
  61. sample.Sid = RawSampleData[0];
  62. sample.Job = RawSampleData[1];
  63. if (RawSampleData[2] == "PYRITE")
  64. {
  65. sample.Pyrite = true;
  66. }
  67. if (RawSampleData[3] == "PLASTIC")
  68. {
  69. sample.Plastic = true;
  70. }
  71. if (RawSampleData[4] == "MANGANESE")
  72. {
  73. sample.Manganese = true;
  74. }
  75. if (RawSampleData[5] == "HAMMEROIL")
  76. {
  77. sample.HammerOil = true;
  78. }
  79. samples.Add(sample);
  80. }
  81. }
  82. }
  83. return (samples,BarcodeFound);
  84. }
  85. }
  86. }