sharepoint结合多个日历spquery arraylist排序

时间:2011-10-25 17:11:45

标签: c# visual-studio-2010 sharepoint sharepoint-2010

在我的代码中,我将所有日历事件存储在名为“arlist”的arraylist中。我想按事件开始日期对arraylist进行排序,以便对所有事件进行排序。关于如何对arraylist进行排序的任何想法?

谢谢! Ĵ

foreach (SPWeb web in CurrentSiteCollection.AllWebs)
        {
            SPListCollection weblists = web.Lists;
            try
            {
                SPList Calist = weblists["Calendar"];
                SPQuery Iquery = new SPQuery();
                Iquery.ExpandRecurrence = true;

                Iquery.Query = "<Where><And><Eq><FieldRef Name='IsPublic'/>" +
                   "<Value Type= 'bit'>1</Value></Eq>" +
                   "<DateRangesOverlap><FieldRef Name=\"EventDate\" /><FieldRef  Name=\"EndDate\" /><FieldRef Name=\"RecurrenceID\" />" +
                   "<Value Type=\"DateTime\"><Month /></Value></DateRangesOverlap>             </And></Where>";
                Iquery.CalendarDate = sdate;
                SPListItemCollection gItems = Calist.GetItems(Iquery);
                if (gItems.Count > 0)
                {

                    arlist.Add(gItems);
                    urlist.Add(string.Format("{0}/{1}?   ID=",Calist.ParentWebUrl,Calist.Forms[PAGETYPE.PAGE_DISPLAYFORM].Url));
                }
            }
            catch (Exception)
            { }

1 个答案:

答案 0 :(得分:0)

为什么不使用泛型集合而不是ArrayList?

声明

 List<SPListItem> arlist = new List<SPListItem>();

这样做

foreach (SPListItem Item in gItems) {
arlist.Add(Item);
}

而不是arlist.Add(gItems);

最后,当您完成所有子网站的循环并添加所有事件时,请按此类排序

arlist.OrderBy((x) => x.Item("EventDate"));

不要忘记添加命名空间system.collections.generic。