zoukankan      html  css  js  c++  java
  • Python之Faker模块,实现造伪测试数据

    一、Faker安装

            Faker是python的第三方模块,主要用来造随机测试数据。

            通过 pip 进行安装:pip install Faker
            验证是否安装成功:pip show faker

    二、Faker使用方法

    from faker import Faker#导入faker模块中的Faker方法
    fake = Faker()#初始化
    name = fake.name()#调用fake的方法
    address = fake.address()
    print(name)
    print(address)
    print(fake.text())
    输出:
    Ms. Michelle Phillips
    PSC 7472, Box 2953
    APO AE 48826

     主要是导入Factory和Generator类,初始化时,实际调用的是Factory.create()方法

     #locale默认是en_US,英文版,zh_CN是中国版。

     #providers指多种生成随机数据的生成器

     

     三、Faker常用函数

    转载于http://testingpai.com/article/1598425457207

    1、地理信息类

    • fake.city_suffix():市,县
    • fake.country():国家
    • fake.country_code():国家编码
    • fake.district():区
    • fake.geo_coordinate():地理坐标
    • fake.latitude():地理坐标(纬度)
    • fake.longitude():地理坐标(经度)
    • fake.postcode():邮编
    • fake.province():省份
    • fake.address():详细地址
    • fake.street_address():街道地址
    • fake.street_name():街道名
    • fake.street_suffix():街、路

    2、基础信息类

    • ssn():生成身份证号
    • bs():随机 company 服务名
    • company():随机 company 名(长)
    • company_prefix():随机 company 名(短)
    • company_suffix():company 性质
    • credit_card_expire():随机信用卡到期日
    • credit_card_full():生成完整信用卡信息
    • credit_card_number():信用卡 ID
    • credit_card_provider():信用卡类型
    • credit_card_security_code():信用卡安全码
    • job():随机职位
    • first_name_female():女性名
    • first_name_male():男性名
    • last_name_female():女姓
    • last_name_male():男姓
    • name():随机生成全名
    • name_female():男性全名
    • name_male():女性全名
    • phone_number():随机生成手机号
    • phonenumber_prefix():随机生成手机号段

    3、数字类

    • numerify():三位随机数字
    • random_digit():0~9 随机数
    • random_digit_not_null():1~9 的随机数
    • random_int():随机数字,默认 0~9999,可以通过设置 min,max 来设置
    • random_number():随机数字,参数 digits 设置生成的数字位数
    • pyfloat():left_digits=5 # 生成的整数位数,right_digits=2 # 生成的小数位数,positive=True # 是否只有正数
    • pyint():随机 Int 数字(参考 random_int()参数)
    • pydecimal():随机 Decimal 数字(参考 pyfloat 参数)

    4、文本加密类

    • pystr():随机字符串
    • random_element():随机字母
    • random_letter():随机字母
    • paragraph():随机生成一个段落
    • paragraphs():随机生成多个段落,通过参数 nb 来控制段落数,返回数组
    • sentence():随机生成一句话
    • sentences():随机生成多句话,与段落类似
    • text():随机生成一篇文章(不要幻想着人工智能了,至今没完全看懂一句话是什么意思)
    • word():随机生成词语
    • words():随机生成多个词语,用法与段落,句子,类似
    • binary():随机生成二进制编码
    • boolean():True/False
    • language_code():随机生成两位语言编码
    • locale():随机生成语言/国际 信息
    • md5():随机生成 MD5
    • null_boolean():NULL/True/False
    • password():随机生成密码,可选参数:length:密码长度;special_chars:是否能使用特殊字符;* * *
    • 参数选项:length:密码长度;special_chars:是否能使用特殊字符;digits:是否包含数字;
      upper_case:是否包含大写字母;lower_case:是否包含小写字母。默认情况:length=10, special_chars=True, digits=True, upper_case=True, lower_case=True
    • digits:是否包含数字;upper_case:是否包含大写字母;lower_case:是否包含小写字母
    • sha1():随机 SHA1
    • sha256():随机 SHA256
    • uuid4():随机 UUID

    5、时间信息类

    • date():随机日期
    • date_between():随机生成指定范围内日期,参数:start_date,end_date
    • date_between_dates():随机生成指定范围内日期,用法同上
    • date_object():随机生产从 1970-1-1 到指定日期的随机日期。
    • date_time():随机生成指定时间(1970 年 1 月 1 日至今)
    • date_time_ad():生成公元 1 年到现在的随机时间
    • date_time_between():用法同 dates
    • future_date():未来日期
    • future_datetime():未来时间
    • month():随机月份
    • month_name():随机月份(英文)
    • past_date():随机生成已经过去的日期
    • past_datetime():随机生成已经过去的时间
    • time():随机 24 小时时间
    • timedelta():随机获取时间差
    • time_object():随机 24 小时时间,time 对象
    • time_series():随机 TimeSeries 对象
    • timezone():随机时区
    • unix_time():随机 Unix 时间
    • year():随机年份

    6、网络基础信息类

    • domain_name():生成域名
    • domain_word():域词(即,不包含后缀)
    • ipv4():随机 IP4 地址
    • ipv6():随机 IP6 地址
    • mac_address():随机 MAC 地址
    • tld():网址域名后缀(.com,.net.cn,等等,不包括。)
    • uri():随机 URI 地址
    • uri_extension():网址文件后缀
    • uri_page():网址文件(不包含后缀)
    • uri_path():网址文件路径(不包含文件名)
    • url():随机 URL 地址
    • user_name():随机用户名
    • image_url():随机 URL 地址

    四、Faker测试数据入库

    import pymysql
    import random
    import time,datetime
    from faker import  Faker
    
    mysql={
        "host":"XXX.XX.XX.XX",
        "port":3306,
        "user":"XX",
        "password":"XX",
        "database":"app_elec_peak",
        "charset":"utf8",
        "autocommit":True
    }
    conn=pymysql.connect(**mysql)#连接数据库
    cursor=conn.cursor()#创建游标
    faker=Faker(locale='zh_CN')#初始化
    p=[]
    kwh=[]
    #生成[['12','23','34'],['23','15','67'],['19','21','10'],['14','4.6','5'],[],[]]类型的数组
    for i in range(7):
        subp=[]
        subKwh=[]
        for j in range(0, 96):
            kw =faker.random_int(min=70, max=100)
            h = kw * 0.25
            subp.append(str(kw))
            subKwh.append(str(h))
        np =','.join(subp)
        nkwh=','.join(subKwh)
        p.append(np)
        kwh.append(nkwh)
    
    company=['100','155','156','157','158','159','160']
    run_date=datetime.date.today()#执行日期取脚本执行当前日期
    create_time=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime())#创建日期取系统当前日期
    for k in range(7):
        sql="insert into company_meter_data(company_id,p,kwh,run_date,create_time)values('%s','%s','%s','%s','%s')"
        %(company[k],p[k],kwh[k],run_date,create_time)
        cursor.execute(sql)
    cursor.close()
    conn.close()

    脚本执行后,成功入库



     

            

  • 相关阅读:
    2018北京网络赛 G The Mole /// 分块暴力 点线距离
    POJ 3525 /// 半平面交 模板
    买不到的数目 /// 结论公式 oj26316
    Number Sequence /// oj21456
    Round Numbers /// 组合计数 oj21455
    POJ 1265 /// 皮克定理+多边形边上整点数+多边形面积
    fread 快速读入 (神奇挂!)
    HDU6395(分段+矩阵快速幂)
    如何得出保留某位小数,不进行四舍五入
    Codeforces1114 D. Flood Fill (DP)(整个区间染成同色)
  • 原文地址:https://www.cnblogs.com/balllyh/p/14066399.html
Copyright © 2011-2022 走看看