Ich mache das durch Looping DataTable
EventDate
und überprüfen Sie es mit vorherigen auf.
Dies ist vb.net
Code:
'get first date from table in format day.month - adapt to Your date format
Dim pDT As String = String.Format("{0:dd.MM}", dt.Rows(0)("EventDate"))
Dim res As String = "<table cellspacing=0 cellpadding=0><tr><td style='text-align:left;vertical-align:top;border-bottom:solid 1px gray;'>" + pDT + "</td><td style='text-align:left;vertical-align:top;padding-bottom:10px;border-bottom:solid 1px gray;padding-left:10px;'>" + dt.Rows(0)("Title") + "<br>"
For x = 1 To dt.Rows.Count - 1
'get EventDate from current row
Dim nD As String = String.Format("{0:dd.MM}", dt.Rows(x)("EventDate"))
If nD <> pDT Then
res += "<td></tr>"
pDT = String.Format("{0:dd.MM}", dt.Rows(x)("EventDate"))
res += "<tr><td style='text-align:left;vertical-align:top;border-bottom:solid 1px gray;'>" + pDT + "</td><td style='text-align:left;vertical-align:top;padding-bottom:10px;border-bottom:solid 1px gray;padding-left:10px;'>" + dt.Rows(x)("Title") + "<br>"
Else
res += dt.Rows(x)("Title") + "<br>"
End If
Next
res += "</td></tr></table>"
lDates.Text = res
Da ich c#
nicht verwenden, Code unten durch Online-Konverter umgewandelt wird (ich hoffe, so ist es richtig Umwandlung :():
string pDT = string.Format("{0:dd.MM}", dt.Rows[0]["EventDate"]);
string res = "<table cellspacing=0 cellpadding=0><tr><td style='text-align:left;vertical-align:top;border-bottom:solid 1px gray;'>" + pDT + "</td><td style='text-align:left;vertical-align:top;padding-bottom:10px;border-bottom:solid 1px gray;padding-left:10px;'>" + dt.Rows[0]["Title"] + "<br>";
for (int x = 1; x <= dt.Rows.Count - 1; x++)
{
string nD = string.Format("{0:dd.MM}", dt.Rows[x]["EventDate"]);
if (nD != pDT)
{
res += "<td></tr>";
pDT = string.Format("{0:dd.MM}", dt.Rows[(x]["EventDate"]);
res += "<tr><td style='text-align:left;vertical-align:top;border-bottom:solid 1px gray;'>" + pDT + "</td><td style='text-align:left;vertical-align:top;padding-bottom:10px;border-bottom:solid 1px gray;padding-left:10px;'>" + dt.Rows[x]["Title"] + "<br>";
}
else
{
res += dt.Rows[x]["Title"] + "<br>";
}
}
res += "</td></tr></table>";
lDates.Text = res;
Es ist wenig verschmutzter Code
Aktualisierung (Repeater
):
Dann müssen Sie neu, leer, DataTable
erstellen und fast gleichen Code verwenden, aber statt string
Werte in neue setzen DataTable
(mit 2 Spalten, eine für Datum und andere für Titel) :
Code-Behind (vb.net):
Dim newDT As New DataTable
newDT.Columns.Add("Date", GetType(String))
newDT.Columns.Add("Titles", GetType(String))
Dim pDT = String.Format("{0:dd.MM}", dt.Rows(0)("EventDate"))
Dim titles As String = dt.Rows(0)("Title") + ","
For x = 1 To dt.Rows.Count - 1
Dim nD = String.Format("{0:dd.MM}", dt.Rows(x)("EventDate"))
If pDT <> nD Then
titles = Mid(titles, 1, Len(titles) - 1)
newDT.Rows.Add({pDT, String.Join("<br>", titles.Split(",").ToArray)})
pDT = String.Format("{0:dd.MM}", dt.Rows(x)("EventDate"))
titles = dt.Rows(x)("Title") + ","
Else
titles += dt.Rows(x)("Title") + ","
End If
Next
titles = Mid(titles, 1, Len(titles) - 1)
newDT.Rows.Add({pDT, String.Join("<br>", titles.Split(",").ToArray)})
rptDate.DataSource = newDT
rptDate.DataBind()
Code-Behind (c#
) (ps Ich bin mir nicht sicher, ob es sich um eine korrekte Konvertierung handelt. sorry, wieder, ich bin sehr, sehr schwach mit c#
:():
DataTable newDT = new DataTable();
newDT.Columns.Add("Date", typeof(string));
newDT.Columns.Add("Titles", typeof(string));
string pDT = string.Format("{0:dd.MM}", dt.Rows[0]["EventDate"]);
string titles = dt.Rows[0]("Title") + ",";
for (x = 1; x <= dt.Rows.Count - 1; x++) {
string nD = string.Format("{0:dd.MM}", dt.Rows[0]["EventDate"]);
if (pDT != nD) {
titles = Strings.Mid(titles, 1, Strings.Len(titles) - 1);
newDT.Rows.Add({
pDT,
string.Join("<br>", titles.Split(",").ToArray)
});
pDT = string.Format("{0:dd.MM}", dt.Rows[x]("EventDate"));
titles = dt.Rows[x]("Title") + ",";
} else {
titles += dt.Rows[x]("Title") + ",";
}
}
titles = Strings.Mid(titles, 1, Strings.Len(titles) - 1);
newDT.Rows.Add({
pDT,
string.Join("<br>", titles.Split(",").ToArray)
});
rptDate.DataSource = newDT;
rptDate.DataBind();
aspx:
<asp:Repeater runat="server" ID="rptDate">
<HeaderTemplate>
<table cellpadding="0" cellspacing="0">
</HeaderTemplate>
<ItemTemplate>
<tr>
<td class="td1">
<%# Container.DataItem("Date")%>
</td>
<td class="td2">
<%# Container.DataItem("Titles")%>
</td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>
css:
.td1, .td2 {width:250px; border-bottom:solid 1px gray; text-align:left; vertical-align:top;}
.td1 {font-weight:bold;}
.td2 {font-style:italic;}
A Gridview? Repeater? – JCM
Ich kann einen Repeater verwenden, aber wie kann ich die DataTable trennen. – Si8
Nun, versuchen Sie eine weitere "DataTable" mit 'distinct' zu erstellen, durchlaufen Sie diese Tabelle und sammeln Sie Werte von der ersten ...etwas unordentlich, aber es könnte den Job erledigt – nelek