FileAccess.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  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 using 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. // Pattern match is for 'ML003092.csv' or 'ML003092_20220822.csv'
  23. var jobFiles = Directory.EnumerateFiles(DataDir, "ML??????*.csv", SearchOption.TopDirectoryOnly);
  24. foreach (var jobFile in jobFiles)
  25. {
  26. bool sampleFound;
  27. (samples, sampleFound) = ReadCSV(barcode, jobFile, samples);
  28. if (sampleFound)
  29. {
  30. return samples;
  31. }
  32. }
  33. }
  34. }
  35. }
  36. catch (Exception ex)
  37. {
  38. MessageBox.Show("An error occurred." + Environment.NewLine + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  39. }
  40. return samples;
  41. }
  42. private static (HashSet<Samples>,bool) ReadCSV(string barcode, string CsvFile, HashSet<Samples> samples)
  43. {
  44. bool BarcodeFound = false;
  45. string[] RawSampleData = new string[1] { "" };
  46. string[] lines = File.ReadAllLines(CsvFile);
  47. foreach (var line in lines)
  48. {
  49. if (line.Contains('\u002C'))
  50. {
  51. RawSampleData = line.Split('\u002C');
  52. }
  53. if (RawSampleData.Length == 9)
  54. {
  55. Samples sample = new();
  56. if (RawSampleData[0] == barcode)
  57. {
  58. BarcodeFound = true;
  59. }
  60. if (RawSampleData[0] != "SAMPLEID")
  61. {
  62. sample.Sid = RawSampleData[0];
  63. sample.Job = RawSampleData[1];
  64. if (RawSampleData[2] == "PYRITE")
  65. {
  66. sample.Pyrite = true;
  67. }
  68. if (RawSampleData[3] == "PLASTIC")
  69. {
  70. sample.Plastic = true;
  71. }
  72. if (RawSampleData[4] == "MANGANESE")
  73. {
  74. sample.Manganese = true;
  75. }
  76. if (RawSampleData[5] == "HAMMEROIL")
  77. {
  78. sample.HammerOil = true;
  79. }
  80. samples.Add(sample);
  81. }
  82. }
  83. }
  84. return (samples,BarcodeFound);
  85. }
  86. }
  87. }