XlCache.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Entity;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using XdCxRhDW.Repostory.EFContext;
  9. using XdCxRhDW.Repostory.Model;
  10. namespace XdCxRhDW.Repostory
  11. {
  12. public static class XlCache
  13. {
  14. public static async Task<List<XlInfo>> GetAllAsync()
  15. {
  16. try
  17. {
  18. List<XlInfo> list = new List<XlInfo>();
  19. if (!Directory.Exists("DbPart")) return list;
  20. var yearDirs = Directory.EnumerateDirectories(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart")).OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name));//年目录,倒叙排列
  21. foreach (var yearDir in yearDirs)
  22. {
  23. //每一天的db文件,倒序排列
  24. var dayFiles = Directory.EnumerateFiles(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, yearDir),"*.db").OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name.Substring(0, 4)));
  25. foreach (var dayFile in dayFiles)
  26. {
  27. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  28. {
  29. list.AddRange(await db.XlInfos.ToListAsync());
  30. if (list.Count > 2000)
  31. return list;
  32. }
  33. }
  34. }
  35. return list;
  36. }
  37. catch (Exception ex)
  38. {
  39. Serilog.Log.Error(ex, "加载星历信息异常");
  40. return null;
  41. }
  42. }
  43. }
  44. }