واضح آرشیو وب فارسی:سایت ریسک: View Full Version : استخراج داده از Xml در Asp.net rtech8th March 2008, 06:44 PMدر اين مقاله با يکی از روشهای ساده استخراج داده از XML به عنوان منبع برای داده های کوچک آشنا می شويم. يکی از انتخاب های ما برای استخراج داده ها از فايلهای xml استفاده از dataset و يا XMLDocument است که با توجه به منابع زيادی که هر دو اينها استفاده می کنند در بعضی شرايط قابل استفاده نيستند. در اين موارد پيشنهاد می شود که از XMLTextReader برای اين منظور استفاده شود. XMLTextReader نوعی دسترسی سريع و روبه جلو (ForwardOnly) را برای ما مهيا ميکند که در ضمن به خاطر ويژگی non-cached بار زيادی به حافظه اعمال نمی کند. چند متدی که معمولا بيشتر استفاده می شوند : ()Read که تقريبا شبيه متد هم نام خود در DataReader عمل می کند. ()ReadElementString متن درون المنت را برمی گرداند. و همچنين ويژگی Item که Attributeها و مقادير آنها را نگهداری ميکند. شما با استفاده از HasAttributes می توانيد مطمئن شويد که يک المنت دارای Attribute هست يا خير. مثال: به اين فايل XML توجه کنيد : <?xml version="1.0" encoding="utf-8" ?> <Root> <data> <id>1</id> <into date="2003-02-18" where="ايران" /> <comment show="true" title="hi!" /> </data> <Root> من برای خواندن Attributeها از المنت comment و متن المنت id از اين فايل XMLای که در بالا آمده اينچنين عمل می کنم: Dim xrdr As New XmlTextReader(path) Dim s, t, id As String While xrdr.Read() If xrdr.HasAttributes And xrdr.name="comment" Then s = xrdr.item("show") t = xrdr.item("title") ElseIf xrdr.name="id" Then id = xrdr.ReadElementString () End If End While xrdr.Close() استفاده از XML به عنوان منابع داده های کوچک می تواند ما را در بسياری از عمليات برنامه های کاربردی وب کمک کند. به خصوص برنامه هايی که به مصرف منابع حساس هستند. منبع : irboys سایت ما را در گوگل محبوب کنید با کلیک روی دکمه ای که در سمت چپ این منو با عنوان +1 قرار داده شده شما به این سایت مهر تأیید میزنید و به دوستانتان در صفحه جستجوی گوگل دیدن این سایت را پیشنهاد میکنید که این امر خود باعث افزایش رتبه سایت در گوگل میشود
این صفحه را در گوگل محبوب کنید
[ارسال شده از: سایت ریسک]
[مشاهده در: www.ri3k.eu]
[تعداد بازديد از اين مطلب: 389]