0

このようなコレクションを持っています

    public class Worksheet
    {
        public string WorksheetName { get; set; }
        public string WorksheetId { get; set; }
        public string TestSymbol { get; set; }
        public string TestId { get; set; }

        public List<Samples> Samples { get; set; }

        public Worksheet()
        {
            Samples = new List<Samples>();
        }
        public Worksheet(string worksheetname, string worksheetid, string testsymbol, string testid)
        {
            WorksheetName = worksheetname;
            WorksheetId = worksheetid;

            TestSymbol = testsymbol;
            TestId = testid;

            Samples = new List<Samples>();
        }

    }
    public class Samples
    {
        public string SampleId { get; set; }
        public string SampleName { get; set; }

        public Samples()
        {
            AssociatedSheets = new List<Worksheet>();
        }

        public Samples(string sampleid, string samplename)
        {
            AssociatedSheets = new List<Worksheet>();

            SampleId = sampleid;
            SampleName = samplename;
        }

        public List<Worksheet> AssociatedSheets { get; set; }
    }

時計で見た時の構造が見える

  • ワークシート 1
    • サンプルA
    • サンプル B
  • ワークシート 2
    • サンプル C
    • サンプルA

私が望むのは、各サンプルで AssociatedSheets を設定して、それを含むワークシートを表示することです。

表示されるように

  • ワークシート 1
    • サンプルA
      • ワークシート 1
      • ワークシート 2
    • サンプル B
      • ワークシート 1
  • ワークシート 2
    • サンプル C
      • ワークシート 2
    • サンプルA
      • ワークシート 1
      • ワークシート 2

私はこのようなものを開発しましたが、明らかにうまくいきません。この後、各サンプルを個別に選択したいと思います。誰かがアドバイスできますか:

        List<Samples> AllSamples = new List<Samples>();

        //Step 4. Add possible worksheets to each sample.
        foreach (Samples sample in sheets.SelectMany(x => x.Samples).ToList())
        {
            List<Worksheet> sampleitem = sheets.SelectMany(x => x.Samples.Select(y => y.SampleId) == sheets.SelectMany(k => k.Samples).Select(h => h.SampleId).ToList());

            sample.AssociatedSheets = AssociatedSheets;

            if (!AllSamples.Contains(sample))
                AllSamples.Add(sample);
        }
4

2 に答える 2

1

[編集]以前の回答からのコード修正

多分これはそれを行うことができます:

List<Sample> allSamples = new List<Sample>();
foreach (Sample sample in sheets.SelectMany(x => x.Samples).Distinct())
{
  var sampleSheets = sheets.Where(s => s.Samples.Contains(sample)).Distinct();
  sample.AssociatedSheets.AddRange(sampleSheets);
  allSamples.Add(sample);
}
于 2013-01-25T09:56:04.477 に答える
1

シンプルですが、仕事をします:

foreach (var grouping in from worksheet in worksheets
                         from sample in worksheet.Samples
                         group worksheet by sample)  // Groups the worksheets by sample
    grouping.Key.AssociatedSheets = grouping.Distinct().ToList();  // grouping.Key is the key of the group (the sample) and ((IEnumerable)grouping) is the elements in the group (the worksheets
于 2013-01-25T11:13:52.060 に答える