Я хочу группировать вопросы и ответы LINQ и правильно отображать их - PullRequest
0 голосов
/ 07 октября 2018

Я пытаюсь сгруппироваться должным образом, чтобы моя ячейка распространялась по вечерам.Распечатка получается очень странной и неровной.

Это таблица, которую я создаю, или группа, или обе?Я думаю, что группа является правильной.Мои результаты, как показано на рисунке ниже.

Золото - заголовок, Зеленый - вопросы, Красный - ответы

enter image description here

enter image description here

Таблица Mt ниже

var Sections = new OncologySection().SelectSections(projectID.ToString());
        int iSection = 0;
        int igroups = 0;
        int ianswer = 0;

        tb.CssClass = "";
        tb.BorderWidth = 1;
        tb.Width = new Unit("780px");
        tb.Attributes.Add("runat", "server");

        foreach (OncologySection section in Sections)
        {
            TableRow row1 = new TableRow();
            iSection++;
                            // var getDistinctQuestion = getVoterAnswerstoList.Select(s => s.QuestionText ,s.Id).Distinct().ToList();

            var getVoterAnswerstoList = new OncologyGeneratePDFDAL().DataforPDFCreation(Convert.ToInt32(projectID), Convert.ToInt32(voterid), Convert.ToInt32(caseId), Convert.ToInt32(voteSurveyId), Convert.ToInt32(section.SectionID)).OrderBy(os => os.SortOrder);

            //var groupedCustomerList = getVoterAnswerstoList
            //    .GroupBy(u => u.QuestionText, u.QuestionText)
            //    .Select(grp => grp.ToList())
            //    .ToList();

            var groupedCustomerList = getVoterAnswerstoList.GroupBy(x => new { x.QuestionText, x.DynamicValue }).ToList();


            TableCell cell1 = new TableCell();
            cell1.BorderWidth = 1;
            cell1.Text = section.SectionName;
            cell1.BorderColor = System.Drawing.Color.Goldenrod;
            cell1.ColumnSpan = groupedCustomerList.Count();
            row1.Cells.Add(cell1);
            tb.Rows.Add(row1);


            TableRow row2 = new TableRow();

            foreach (var groups in groupedCustomerList)
            {
                igroups++;

                TableCell cell2 = new TableCell();

                var q = (from s in groups select s.QuestionText).FirstOrDefault();
                cell2.BorderWidth = 1;
                cell2.Text = q;
                cell2.BorderColor = System.Drawing.Color.Green;
                cell2.ColumnSpan = groupedCustomerList.Count();
                row2.Cells.Add(cell2);


                if (igroups == groupedCustomerList.Count())
                {
                    tb.Rows.Add(row2);
                }
                else
                {
                    row2.Cells.Add(cell2);
                }
                TableRow row3 = new TableRow();
                foreach (var answers in groups)
                {

                    ianswer++;

                    TableCell cell3 = new TableCell();

                    cell3.BorderWidth = 1;

                    cell3.BorderColor = System.Drawing.Color.DarkRed;
                    if (answers.DataTypeId == 7)
                    {
                        cell3.Text = answers.DynamicValue.ToString();
                    }
                    else if ((answers.DataTypeId == 5) || (answers.DataTypeId == 6) || (answers.DataTypeId == 8))
                    {

                        if (answers.VotingValue != 0)
                        {
                            cell3.Text = answers.VotingValue.ToString();
                        }
                        else
                        {
                            cell3.Text = " ";
                        }
                    }
                    else
                    {

                        cell3.Text = " ";
                    }

                    row3.Cells.Add(cell3);
                    tb.Rows.Add(row3);
                }

            }

        } 

    }
...