我有一个名为'Complex'的类型列表:
List<Complex> list = new List<Complex>();
...
class Complex
{
public string Header { get; set; }
...
...
...
}
列表中有一些重复的标题,这些标题表示新节的开头。每个部分的长度可能不同,如下所示:
start 1 2 3 4 5 6 7 start 1 2 3 start 1 2 3 4 5 6 start 1 start 1 2
我想使用LINQ获取所有可能的Complex类型的子列表;也就是说,所有带标题的对象如下:
如何仅使用LINQ实现此目的?
编辑: 列表是在html页面解析期间创建的
<tr>
<td>00:00<!--//-00:00--></td>
<td>15:00<!--//-00:00--></td>
<td class="txt_left"><a href="">News</a></td>
<td><a href="/TsV2/TV_Video_On.asp?PROG_CODE=TVCR0114">
<img src="/images/new/sub_new/icon_play01_off.gif" alt="play" class="rollover"/></a></td>
</tr>
<tr>
<td>00:15<!--//-00:00--></td>
<td>15:15<!--//-00:00--></td>
<td class="txt_left">
<a href="Tv_Pagego.asp?PROG_CODE=TVCR0556">Nice one</a></td>
<td><a href="/TV2w/TV_2Video_On.asp?PROG_CODE=TVCR0556"><img src="/images/new/sub_new/icon_play01_off.gif" alt="play" class="rollover"/></a></td>
</tr>
答案 0 :(得分:2)
static void Main(string[] args)
{
var seq = new object[] {"start", 1, 2, 3, 4, "start", 1, 2, 3, "start", 1, 2, "start", 1};
var no = 0;
var test = (from i in seq select new {SeqNo = (i.ToString() == "start" ? no++ : no), Item = i}).Where( x => x.Item.ToString() != "start").GroupBy( y => y.SeqNo ).Select( z => z.ToArray()).ToArray();
}
或
var test = (from i in seq
group i by i.ToString() == "start" ? ++no : no into g
select g.Where( gi => gi.ToString() != "start" ).ToArray()
).ToArray()
;
ToArray 语句不是必需的
答案 1 :(得分:0)
这个问题对我来说并不清楚,但这里有一些提示:
答案 2 :(得分:0)
var List = new List<Complex>()
{
new Complex() { Header = "start" },
new Complex() { Header = "00:23" },
new Complex() { Header = "00:33" },
new Complex() { Header = "start" }
};
var query = List.GroupBy(x => x.Header);
这应该导致3个IGroupings一个带标题&#34;开始&#34;与&#34; 00:23&#34;和#34; 00:33&#34;
更具体地说,查询将返回IEnumerable&gt;密钥将成为您的标题。元素将是你的类型(复杂)。
编辑:不是问题,但这似乎是:)
var seq = new object[] {"start", 1, 2, 3, 4, "start", 1, 2, 3, "start", 1, 2, "start", 1}.ToList();
while(seq.Count() != 0)
{
var Output = seq.SkipWhile(x => x.ToString() != "start").Skip(1).TakeWhile(x => x.ToString() != "start");
seq.RemoveRange(0, Output.Count() +1);
}
我喜欢它......