51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2083|回复: 7
打印 上一主题 下一主题

selenium读取excel数据为浮点,如何处理?

[复制链接]
  • TA的每日心情
    无聊
    2018-5-10 09:16
  • 签到天数: 172 天

    连续签到: 2 天

    [LV.7]测试师长

    跳转到指定楼层
    1#
    发表于 2017-1-25 10:33:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    selenium读取excel数据为浮点,如何处理?

    1、文档第一列为用户名,可能是字符串/数字,第二列为密码,可能是字符串/数字
    2、我想直接读出第一列用户名作为列表,读出第二列密码作为列表
    3、整理列表为字典
    4、for循环遍历字典用户名和密码为元祖,并代入登录代码中
    如何便捷的转换浮点为int类型,但是其中还有字符串?



    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏1
    回复

    使用道具 举报

  • TA的每日心情
    慵懒
    2017-11-7 16:44
  • 签到天数: 290 天

    连续签到: 1 天

    [LV.8]测试军长

    2#
    发表于 2017-1-25 14:00:46 | 只看该作者
    如何便捷的转换浮点为int类型,但是其中还有字符串?

    加个判断条件,将浮点型的数据转换成int,字符串的保持不动:
    float_num = 0.1
    if type(username) == type(float_num):
        username = int(username)
    else:
        pass


    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2018-5-10 09:16
  • 签到天数: 172 天

    连续签到: 2 天

    [LV.7]测试师长

    3#
     楼主| 发表于 2017-1-25 14:16:11 | 只看该作者
    若尘_51 发表于 2017-1-25 14:00
    如何便捷的转换浮点为int类型,但是其中还有字符串?

    加个判断条件,将浮点型的数据转换成int,字符串的 ...

    谢谢
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2018-5-10 09:16
  • 签到天数: 172 天

    连续签到: 2 天

    [LV.7]测试师长

    4#
     楼主| 发表于 2017-1-25 14:16:33 | 只看该作者
    若尘_51 发表于 2017-1-25 14:00
    如何便捷的转换浮点为int类型,但是其中还有字符串?

    加个判断条件,将浮点型的数据转换成int,字符串的 ...

    for username,password in user.items():
            if type(username)!=str:
                    username=int(username)
            if type(password)!=str:
                    password=int(password)
    我这样写了  哈哈哈  2个if是否可以合成1个呢
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2017-11-7 16:44
  • 签到天数: 290 天

    连续签到: 1 天

    [LV.8]测试军长

    5#
    发表于 2017-1-25 15:03:51 | 只看该作者
    很不错啊。已经最简了吧
    还有一种方法也可以:
    try:
        username=int(username)
        password= int(password)
    except:
        try:
            password=int(password)
        except:
            pass
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2018-5-10 09:16
  • 签到天数: 172 天

    连续签到: 2 天

    [LV.7]测试师长

    6#
     楼主| 发表于 2017-1-25 16:51:29 | 只看该作者
    若尘_51 发表于 2017-1-25 15:03
    很不错啊。已经最简了吧
    还有一种方法也可以:
    try:

    谢谢了
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2018-5-10 09:16
  • 签到天数: 172 天

    连续签到: 2 天

    [LV.7]测试师长

    7#
     楼主| 发表于 2017-1-25 16:54:28 | 只看该作者
    若尘_51 发表于 2017-1-25 15:03
    很不错啊。已经最简了吧
    还有一种方法也可以:
    try:

    我想把测试报告写入excel中,一行或一列
    时间 用户名 密码 登录成功/失败
    目前不知如何写,也不知放入那个位置好点



    #!/usr/bin/env python
    #_*_coding:utf-8_*_
    from selenium import webdriver
    import time,xlrd,xlwt
    from selenium.webdriver.common.action_chains import ActionChains
    def OpenUrl():#启动访问域名
        driver=webdriver.Chrome()
        driver.maximize_window()
        driver.get('http://aibbtest.huoxiu.tv')
        return driver
    def UserData():#导入excel数据
        book=xlrd.open_workbook('E:\\test.xlsx')
        sheet=book.sheet_by_index(0)
        col_username=sheet.col_values(0)
        col_password=sheet.col_values(1)
        login_data=dict(zip(col_username,col_password))
        return login_data
    def login(dribver,username,password):
        driver.find_element_by_link_text('登录').click()
        driver.switch_to_frame(driver.find_element_by_xpath('//iframe[@id="layui-layer-iframe1"]'))
        time.sleep(2)
        driver.find_element_by_xpath('//input[@placeholder="手机号/账号/邮箱"]').send_keys(username)
        driver.find_element_by_xpath('//input[@placeholder="请输入密码"]').send_keys(password)
        driver.find_element_by_xpath('//input[@value="登录"]').click()
        driver.switch_to_default_content()
        time.sleep(2)
        center=driver.find_element_by_xpath('//div[@class="user-info hasLogin"]/div[1]/span')
        time.sleep(2)
        ActionChains(driver).move_to_element(center).perform()
        #book =xlwt.Workbook(encoding='utf-8')
        sheet = book.add_sheet('test_sheet',cell_overwrite_ok=True)
        #i=0
        try:
            driver.find_element_by_xpath('//a[@class="loginOut"]').click()
            print('登录成功')
            #sheet.write(0,i+1,'登录成功')
        except:
            print('未登录成功')
            #sheet.write(0,i+1,'登录失败')
        time.sleep(2)
        try:
            driver.find_element_by_link_text('登录').click()
            print('退出账号成功')
        except:
            print('退出账号失败')
        #book.save("E:\\test1.xls")
        time.sleep(2)
        driver.close()
    user=UserData()
    for username,password in user.items():
        if type(username)!=str:
            username=int(username)
        if type(password)!=str:
            password=int(password)
        driver=OpenUrl()
        login(driver,username,password)


    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2017-11-7 16:44
  • 签到天数: 290 天

    连续签到: 1 天

    [LV.8]测试军长

    8#
    发表于 2017-1-26 11:00:23 | 只看该作者
    黑盒测试 发表于 2017-1-25 16:54
    我想把测试报告写入excel中,一行或一列
    时间 用户名 密码 登录成功/失败
    目前不知如何写,也不知放入 ...

    现在你写的不可以吗?    报什么错
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-23 08:59 , Processed in 0.075251 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表