前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >利用php脚本+redis,生成CSV测试文件,重复率为20%

利用php脚本+redis,生成CSV测试文件,重复率为20%

作者头像
句小芒
发布2022-12-29 18:03:10
6890
发布2022-12-29 18:03:10
举报
代码语言:javascript
复制
<?php
/**
 * Created by PhpStorm.
 * User: 1612953660@qq.com
 * Date: 2019/2/28
 */
// 头部标题
$csv_header = ['数据'];
$redis = new redis();
$redis->connect('127.0.0.1',6379);

// 内容
/**
 * 开始生成
 * 1. 首先将数组拆分成以逗号(注意需要英文)分割的字符串
 * 2. 然后加上每行的换行符号,这里建议直接使用PHP的预定义
 * 常量PHP_EOL
 * 3. 最后写入文件
 */
// 打开文件资源,不存在则创建
$fp = fopen('data_test.csv','a');
// 处理头部标题
$header = implode(',', $csv_header) . PHP_EOL;
// 处理内容
$content = '';
$total = 100000;//总条数
$num1 = 0.8*$total;//不重复条数
$num2 = $total-$num1;//重复条数
for($i=0;$i<$num1;$i++){
   $data = make_password();
   $content .=  $data . PHP_EOL;
   $redis->SADD('tempdata',$data);
}
$data2 = $redis->SRANDMEMBER('tempdata',$num2);
foreach ($data2 as $k => $v) {
     $content .= $v . PHP_EOL;
}

// 拼接
$csv = $header.$content;
// 写入并关闭资源
fwrite($fp, $csv);
fclose($fp);
//清除redis缓存
$redis->DEL('tempdata');
/*
*生成随机64位测试数据*
*@param $length
*/
function make_password( $length = 64 )
{
    // 密码字符集,可任意添加你需要的字符
    $chars = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
    'i', 'j', 'k', 'l','m', 'n', 'o', 'p', 'q', 'r', 's',
    't', 'u', 'v', 'w', 'x', 'y','z', 'A', 'B', 'C', 'D',
    'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L','M', 'N', 'O',
    'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y','Z',
    '0', '1', '2', '3', '4', '5', '6', '7', '8', '9');
    // 在 $chars 中随机取 $length 个数组元素键名
//    $keys = array_rand($chars, 1); 
    $password = '';
    for($i = 0; $i < $length; $i++)
    {
        //$keys = array_rand($chars, 1);  
        // 将 $length 个数组元素连接成字符串
        $password .= $chars[array_rand($chars, 1)];
    }
    return $password;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-02-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档