java-appium,jxl调用Excel中的数据,输入到文本框中。

java-appium,jxl调用Excel中的数据,输入到文本框中。

第一次写博客,请多多指教,使用appium调用Excel中的数据,输入到文本框中。

我分享的是我最近在研究的成果。

1、通过appium自动化添加好友。

首先需要做的是,搭建appium环境,这里我就不说了,百度有很多。

这里我使用的语言是java。

首先我们需要的是jar包,因为appium搭建是需要配合selenium使用。

读取Excel中的数据,需要用到jxl.jar包。

下面这是我的jar。

jxl.jar

testng-6.9.9.jar

selenium-java-3.3.1.zip

selenium-server-standalone-3.3.1.jar

java-client-54.1.2.jar

2、接下来就是手机连接电脑,启动appium。然后就是编写脚本,

下面是本人自己通过各种搜索到的,然后再自己编写的代码。

package weixing;




import org.openqa.selenium.By;


import org.openqa.selenium.NoSuchElementException;


import org.openqa.selenium.remote.DesiredCapabilities;


import io.appium.java_client.android.AndroidDriver;


import java.net.MalformedURLException;


import java.net.URL;


import java.io.File;  


import java.io.IOException;  


import jxl.Cell;  


import jxl.Sheet;  


import jxl.Workbook;  


import jxl.read.biff.BiffException;  


@SuppressWarnings("rawtypes")
public class tianJia { 

       
static boolean isContentAppeared(AndroidDriver driver,String content) {  //通过xpath定位元素判断操作进行,因为微信有时会出现查找不到好友,还有就是已经添加过该好友的情况,所以添加用来做判断。
       
       boolean status=true;
       
   try {  
    
       driver.findElement(By.xpath(content)); 
       
       status = true;  
       }
   catch(NoSuchElementException e){  
    
       status = false;  
   }
return status;  
}  

public static void main(String[] args) throws MalformedURLException, InterruptedException,BiffException, IOException{
//*****************************************注意1.
        DesiredCapabilities capabilities = new DesiredCapabilities();  
        
        capabilities.setCapability("deviceName", "53751994");//
        
        capabilities.setCapability("automationName", "Appium");
        
        capabilities.setCapability("platformName", "Android");
        
        capabilities.setCapability("platformVersion", "6.0.1");
        
        capabilities.setCapability("appPackage", "com.tencent.mm");
        
        capabilities.setCapability("appActivity", "com.tencent.mm.ui.LauncherUI");
        
        capabilities.setCapability("noReset", "True");
        
        capabilities.setCapability("unicodeKeyboard", "True");//设置输入的编码
        
        capabilities.setCapability("resetKeyboard", "True");
        
        capabilities.setCapability("autoWebview", "True");    //支持自动切换webview
        
        capabilities.setCapability("recreateChromeDriverSessions", "True");
      
        AndroidDriver driver = new AndroidDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);

//从上面*****************************注意1,到这里,这是启动微信的关键参数。以下是操作步骤。
        
        Thread.sleep(4000);//设置等待时间
       
        driver.findElementById("com.tencent.mm:id/fr").click();//点击+
        
        Thread.sleep(1000);
        
        driver.findElementByName("添加朋友").click();//点击添加朋友
        
        Thread.sleep(1000);
        
        driver.findElementById("com.tencent.mm:id/h9").click();//点击输入框
        
        Thread.sleep(1000);
        
    Workbook book=Workbook.getWorkbook(new File("C:\\test.xls"));//调用Excel中的数据的路径,这里是Excel文件的路径,注,这里只能是以   .xls    结尾,也就是    右键单击>新建> 新建Microsoft Excel 97-2003 工作表.xls
      
    Sheet sheet=book.getSheet(0);//获得第一个工作表对象      getShoot(1)获取Excel文件转中的   第二个工作表。
   
    for(int a=0;a>=0;a++){//这里开时循环,自动化循环添加好友。
    //****************************************************************** 
    Cell cell1=sheet.getCell(0,a);//(0.0)得到第一列第一行的单元格   (0.1)得到第一列第二行的单元格    (1.0)得到第二列第一行的单元格
   
    String result=cell1.getContents();//     定义结果的数据类型
   
    System.out.println(result);//打印结果                 到这里,是获取Excel中的数据。
    //****************************************************************************
        driver.findElementById("com.tencent.mm:id/h9").sendKeys(result);//输入电话号码
        
        Thread.sleep(2000);
        
        driver.findElementById("com.tencent.mm:id/aqb").click();//点击搜索
        
        Thread.sleep(3000);
        
        if(isContentAppeared(driver,"//android.widget.Button[@resource-id=\"com.tencent.mm:id/ah1\"]" )==true){ //调用上面的的isContentAppeared(driver,“    xpath”),判断     添加到通讯录       元素是否存在
       
        driver.findElementById("com.tencent.mm:id/ah1").click();//点击添加到通讯录
       
        Thread.sleep(2000);
       
            driver.findElementById("com.tencent.mm:id/chg").clear();//清除备注名
            
            Thread.sleep(2000);
            //***********************************************再次获取表中的数据
            Cell beiZhu=sheet.getCell(1,a);//得到第二列
            
            Cell beiZhu1=sheet.getCell(2,a);//得到
            
        String result1=beiZhu.getContents();
       
        String result2=beiZhu1.getContents();
       
        System.out.print(result1+"("+result2+")");
       
        driver.findElementById("com.tencent.mm:id/chg").sendKeys(result1+"("+result2+")");//输入备注名
       
            Thread.sleep(2000);
            
            driver.findElementById("com.tencent.mm:id/gv").click();//点击发送
            
            Thread.sleep(1000);
            
            driver.findElementById("com.tencent.mm:id/hd").click();//点击返回
            
            Thread.sleep(1000);
            
            driver.findElementById("com.tencent.mm:id/h9").clear();//清空
            
            Thread.sleep(2000);
            
            System.out.print("成功发送验证信息!");
            
        }
        else if(isContentAppeared(driver,"//android.widget.Button[@resource-id=\"com.tencent.mm:id/ah2\"]")==true){
       
        driver.findElementById("com.tencent.mm:id/hd").click();//点击返回
       
        Thread.sleep(2000);
       
        driver.findElementById("com.tencent.mm:id/h9").clear();//清空
       
            Thread.sleep(2000);
            
            System.out.print("用户已经添加为好友!");
        }
        else{
       
        driver.findElementById("com.tencent.mm:id/h9").clear();//清空
       
        System.out.print("该用户不存在");
        }
        
        System.out.print("              又添加"+a+"行!");
        
    }
    
        driver.quit();
        
        System.out.println("添加完成");
}
}

3、然后运行一下,只要appium搭建和使用没问题,应该可以跑起来。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111430.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 出现将截断字符串或二进制数据怎么办_数据库从字符串转换日期失败

    出现将截断字符串或二进制数据怎么办_数据库从字符串转换日期失败原因是因为在数据库的表中进行了输入字符长度的限制,比如数据库表中的字段长度为5个varchar,而在前台的输入中超出了这个长度就会报这个错。出现此错的原因一般时:在进行数据测试时没有考虑数据的长度,只顾着测试方便乱输一通,稍有不慎就会多出一两个字节(我就是这种情况,在数据库中有一个表示状态的字段,是一个长度的int,但是我输入了双数)解决办法当然简单:只需要更改数据库中的字段长度或者在前台测试输…

    2022年10月7日
    0
  • 11种经典滤波算法「建议收藏」

    11种经典滤波算法「建议收藏」1、限幅滤波法(又称程序判断滤波法)  A、方法:      根据经验判断,确定两次采样允许的最大偏差值(设为A)      每次检测到新值时判断:      如果本次值与上次值之差<=A,则本次值有效      如果本次值与上次值之差>A,则本次值无效,放弃本次值,用上次值代替本次值  B、优点:      能有效克服因偶然因素引起的脉冲干扰…

    2022年5月3日
    66
  • R语言基本画图「建议收藏」

    R语言创建多个图形方法一:每次创建一副新图形之前打开一个新的图形窗口dev.new()画图dev.new()画图……方法二:通过图形用户界面。windows上,打开一个一个图形界面,勾选“历史”——“记录”。然后点击菜单中的“上(下)一个”即可。方法三:使用函数dev.new()、dev.next()、dev.prev()、dev.set()

    2022年4月13日
    326
  • 图书销售管理系统概要设计,系统数据结构设计分工

    图书销售管理系统概要设计,系统数据结构设计分工完成人:千城墨白(20160401095)无法无天(20160401115)系统数据结构设计1、逻辑结构设计要点2、物理结构设计要点(1)系统所用到所有数据均存在服务器端,存于SQLServer服务器中;(2)系统界面的显示属性,如字体属性,样式等使用CSS统一界面;(3)系统界面中使用的相关图片需要保存在服务…

    2022年5月13日
    37
  • Android 的CompoundButton(抽象类按钮)、StringBuffer(字符串变量)「建议收藏」

    Android 的CompoundButton(抽象类按钮)、StringBuffer(字符串变量)「建议收藏」1、写在前面的话本人40岁纯小白一枚,最近对AndroidAPP有了兴趣,目前的任务:通过AndroidStudio利用Apchepoi、EasyExcel等第三方库,编写APP,实现移动端APP与后台Excel的数据交互。这次利用CSDN平台记录下自己的成长。纯属小白,有概念或者描述错误,希望大佬们不吝赐教,再此谢过。2、任务目标目前正在学习这本书,在做P110页的作业时,发现的问题:作业要求,点击“进入主页”的按钮,一次性获取已近选取的多选框的text属性,然后Toast出

    2022年7月18日
    10
  • Spring Boot @WebFilter不起作用的问题

    Spring Boot @WebFilter不起作用的问题

    2021年5月16日
    153

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号