簡體   English   中英

如何向此XML添加其他過濾器

[英]How to add an additional filter to this XML

我有以下C#代碼來解析xml文檔:

XDocument.Load(ConfigurationManager.AppSettings["XDocumentLoad"])
    .Root
    .Elements(j + "RegisteredOffenders")
    .ToList()
    .ForEach(element =>
    {
        //build out the xml namespace for the data parse
        var ns = element.GetDefaultNamespace();
        var role = element.Element(ns + "RoleOfPerson");
        var PersonName = role.Element(ns + "PersonName");
        var offender = element.Element(j + "RegisteredOffenderIdentification");
        var id = element.Attribute(s + "id").Value;

        //This is an inner loop that gets all the addresss for a person and writes the info to the temp strings declared above.
        element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Where(a => a.Element(se + "offenderIdRef").Value == id).ToList().ForEach(ad =>
        {
            string aCode = ad.Element(sc + "AddressCategoryCode").Value;
            switch (aCode.ToUpper())
            {
                case "TEMP":
                    string TempAddressCode = ad.Element(sc + "AddressCategoryCode").Value;
                    string TempStreet = ad.Element(ns + "LocationStreet").Element(ns + "StreetFullText").Value;
                    string Tempcity = ad.Element(ns + "LocationCityName").Value;
                    string Tempstate = ad.Element(sc + "LocationUSStateCode").Value;
                    string TempzipOne = ad.Element(ns + "LocationPostalCode").Value;
                    string TempzipTwo = ad.Element(ns + "LocationPostalExtensionCode").Value;
                    TempLocation = string.Format("{0},{1},{2},{3},{4}", TempStreet, Tempcity, TempStreet, TempzipOne, TempzipTwo);
                    break;

                case "PERM":
                    string PermAddressCode = ad.Element(sc + "AddressCategoryCode").Value;
                    string PermStreet = ad.Element(ns + "LocationStreet").Element(ns + "StreetFullText").Value;
                    string Permcity = ad.Element(ns + "LocationCityName").Value;
                    string PermCounty = ad.Element(sc + "LocationNonFLCounty").Value;
                    string Permstate = ad.Element(sc + "LocationUSStateCode").Value;
                    string PermzipOne = ad.Element(ns + "LocationPostalCode").Value;
                    string PermzipTwo = ad.Element(ns + "LocationPostalExtensionCode").Value;
                    PermLocation = string.Format("{0},{1},{2},{3},{4},{5}", PermStreet, Permcity, PermCounty, Permstate, PermzipOne, PermzipTwo);
                    break;

                case "TRANS":
                    string TransAddressCode = ad.Element(sc + "AddressCategoryCode").Value;
                    string TransStreet = ad.Element(ns + "LocationStreet").Element(ns + "StreetFullText").Value;
                    string Transcity = ad.Element(ns + "LocationCityName").Value;
                    string Transstate = ad.Element(sc + "LocationUSStateCode").Value;
                    string TranszipOne = ad.Element(ns + "LocationPostalCode").Value;
                    string TranszipTwo = ad.Element(ns + "LocationPostalExtensionCode").Value;
                    TransLocation = string.Format("{0},{1},{2},{3},{4}", TransStreet, Transcity, TransStreet, TranszipOne, TranszipTwo);
                    break;
            }
        }
    );

現在,我需要添加到linq查詢中以進一步過濾數據。 現在正在過濾的數據點是xml地址部分中的縣信息。 我嘗試使用此代碼,但無法編譯。

XDocument.Load(ConfigurationManager.AppSettings["XDocumentLoad"])
    .Root
    .Elements(j + "RegisteredSexOffender")
    .ToList()
    .ForEach(element =>
    {
        //build out the xml namespace for the data parse
        var ns = element.GetDefaultNamespace();
        var role = element.Element(ns + "RoleOfPerson");
        var PersonName = role.Element(ns + "PersonName");
        var offender = element.Element(j + "RegisteredOffenderIdentification");
        var id = element.Attribute(s + "id").Value;

        //This is an inner loop that gets all the addresss for a person and writes the info to the temp strings declared above.
        element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Where(a => a.Element(se + "offenderIdRef").Value == id) && element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Elemetns(sc + "LocationNonFLCounty").Value=="ORANGE").ToList().ForEach(ad =>
        {

如您所見,我嘗試在linq語句中添加and子句,但沒有走運。

我能夠得到這行代碼進行編譯,但是現在我沒有任何記錄

                            element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Where(a => a.Element(se + "offenderIdRef").Value == id && a.Element(sc + "LocationNonFLCounty").Value == "Orange").ToList().ForEach(ad =>

您需要學習對代碼進行細分。 像這樣的單線很難讀。

element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Where(a => a.Element(se + "offenderIdRef").Value == id).ToList().ForEach(ad =>
// this line has 334 characters...
element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Where(a => a.Element(se + "offenderIdRef").Value == id) && element.Document.Root.Element(se + "SopsOffenderAddressList").Elements(se + "SopsOffenderAddress").Elemetns(sc + "LocationNonFLCounty").Value=="ORANGE").ToList().ForEach(ad =>

這是第二行,您要修改的第二行:

element.Document.Root
    .Element(se + "SopsOffenderAddressList")
    .Elements(se + "SopsOffenderAddress")
    .Where(a => a.Element(se + "offenderIdRef").Value == id)
&& // this is not how you 'add' another 'filter'(where clause)
element.Document.Root
    .Element(se + "SopsOffenderAddressList")
    .Elements(se + "SopsOffenderAddress")
    .Elemetns(sc + "LocationNonFLCounty").Value=="ORANGE") // I think you mean to compare a *single* element to "ORANGE"

    .ToList().ForEach(ad =>

您需要鏈接您的where子句或將它們合並在同一where子句中:

element.Document.Root
    .Element(se + "SopsOffenderAddressList")
    .Elements(se + "SopsOffenderAddress")

    // chaining (pick one)
    .Where(a => a.Element(se + "offenderIdRef").Value == id)
    .Where(a => a.Element(sc + "LocationNonFLCounty").Value == "ORANGE")

    // combined (pick one)
    .Where(a =>
        a.Element(se + "offenderIdRef").Value == id && 
        a.Element(sc + "LocationNonFLCounty").Value == "ORANGE")

    .ToList().ForEach(ad =>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM