android XML解析之PULL及单元测试

本文提供了一个使用Pull解析器从XML文件中读取并解析人员信息的示例代码。通过该示例,开发者可以了解如何利用Android平台上的Pull解析器进行XML数据的解析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我也不多说直接贴代码

 

package com.yf.pullxmlpare;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import org.xmlpull.v1.XmlPullParser;

import android.util.Xml;

//package com.yf.pullxmlpare.person;

public class PersonService {
 public static List<person> getPersons(InputStream xml) throws Exception{
  List<person> person1 = null;
  person ps=null;
  XmlPullParser PullParser = Xml.newPullParser();
  PullParser.setInput(xml, "UTF-8");
  
  int event = PullParser.getEventType();
  
  while(XmlPullParser.END_DOCUMENT != event){
   switch(event){
   case XmlPullParser.START_DOCUMENT:
    person1 = new ArrayList<person>(); //做初始化
    break; 
   case XmlPullParser.START_TAG: //2
    if("person".equals(PullParser.getName())){
     int id = new Integer( PullParser.getAttributeValue(0));
     ps = new person();
     ps.setId(id);
    }
    if("name".equals(PullParser.getName())){
     String s = PullParser.nextText();
     ps.setName(s);
    }
    if("age".equals(PullParser.getName())){
     int age = new Integer( PullParser.nextText());
     ps.setAge(age);
    }
    
    break;
   case XmlPullParser.END_TAG:
    if("person".equals(PullParser.getName())){
     person1.add(ps);
     ps = null;
    }
    break;
   case XmlPullParser.END_DOCUMENT:
    break;
   default:
    break;
   }
   
   event = PullParser.next(); //移动指针向后面的元素   
  }
   

  return person1;  
 }

}

 

 

mainfest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.yf.pullxmlpare"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.yf.pullxmlpare.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
<uses-library android:name="android.test.runner" />
     </application>
<instrumentation  android:targetPackage="com.yf.pullxmlpare"
    android:name="android.test.InstrumentationTestRunner"
    android:label="Testfor my app"
    /> 

</manifest>

 

单元测试代码

package testxml;

import java.io.InputStream;
import java.util.List;

import com.yf.pullxmlpare.PersonService;
import com.yf.pullxmlpare.person;

 

import android.test.AndroidTestCase;
import android.util.Log;

public class TestXML extends AndroidTestCase {
 private final String TAG = "TestXML"; 
 public void testperson() throws Exception{
  InputStream xml = this.getClass().getClassLoader().getResourceAsStream("person.xml");
  List<person> ps1 = PersonService.getPersons(xml);
  for(person personx:ps1){
   Log.i(TAG, personx.toString());
   
  }
 }
}

 


 

 

 

资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在本文中,我们将探讨如何通过 Vue.js 实现一个带有动画效果的“回到顶部”功能。Vue.js 是一款用于构建用户界面的流行 JavaScript 框架,其组件化和响应式设计让实现这种交互功能变得十分便捷。 首先,我们来分析 HTML 代码。在这个示例中,存在一个 ID 为 back-to-top 的 div 元素,其中包含两个 span 标签,分别显示“回到”和“顶部”文字。该 div 元素绑定了 Vue.js 的 @click 事件处理器 backToTop,用于处理点击事件,同时还绑定了 v-show 指令来控制按钮的显示与隐藏。v-cloak 指令的作用是在 Vue 实例渲染完成之前隐藏该元素,避免出现闪烁现象。 CSS 部分(backTop.css)主要负责样式设计。它首先清除了一些默认的边距和填充,对 html 和 body 进行了全屏布局,并设置了相对定位。.back-to-top 类则定义了“回到顶部”按钮的样式,包括其位置、圆角、阴影、填充以及悬停时背景颜色的变化。此外,与 v-cloak 相关的 CSS 确保在 Vue 实例加载过程中隐藏该元素。每个 .page 类代表一个页面,每个页面的高度设置为 400px,用于模拟多页面的滚动效果。 接下来是 JavaScript 部分(backTop.js)。在这里,我们创建了一个 Vue 实例。实例的 el 属性指定 Vue 将挂载到的 DOM 元素(#back-to-top)。data 对象中包含三个属性:backTopShow 用于控制按钮的显示状态;backTopAllow 用于防止用户快速连续点击;backSeconds 定义了回到顶部所需的时间;showPx 则规定了滚动多少像素后显示“回到顶部”按钮。 在 V
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

勇敢爱

VX找我475566936

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值