工具(4)——AI自动生成与测试数据的构建

​ 开发里面测试数据构建

主要是构建一些项目的测试数据,有俩种方法,一种内部根据逻辑关系构建,自动对数据表进行批量增加和关联,第二种是外部使用接口模拟自动化操作流程。开发类的项目,需要初期掌握构建数据表相关信息。

整理下常用的生成场景,方便需要集成数据生成开发的使用。
随机用户的生成: (场景,系统需要10-100个用户的某个指标参与排名 或者模拟圈子里加了好友的情形)
涉及到随机手机号码的生成: (号码规律13开头,11位,需要生成用户随机手机号)

     function  getRndPhone() {
        $prefix = mt_rand(130, 199);
        $middle = mt_rand(1000, 9999);
        $last = mt_rand(10000, 99999);
        return $prefix. $middle. $last;
    }

随机昵称的构建: 使用到array_rand 获取随机的一个位置,修饰+名词(填充自己的修饰词库即可)

function getRandomNickname() {
    $adjectives = ['可爱的', '帅气的', '聪明的', '勇敢的', '温柔的', '活泼的'];
    $nouns = ['兔子', '猫咪', '小鸟', '老虎', '狮子', '星星'];
    $randomAdjective = $adjectives[array_rand($adjectives)];
    $randomNoun = $nouns[array_rand($nouns)];
    return $randomAdjective. $randomNoun;
}

真实名称的构建: 姓 + 名字 一起 昵称可以更灵活,名字受到的字库限制比较多

function getRandRealName(){
       $xing = ['赵','钱','孙','李','周','吴','郑','王','冯','陈','褚','卫','蒋','沈','韩','杨','朱','秦','尤','许','何','吕','施','张','孔','曹','严','华','金','魏','陶','姜'];
        $ming = ['子璇','淼','国栋','夫子','瑞堂','甜','敏','尚','国贤','贺','晨涛','昊轩','易轩','益辰','益帆','益冉','瑾春','瑾昆','春齐','杨','文昊','东东','雄霖','浩晨','熙涵','溶溶','冰枫','欣欣','宜豪','欣慧','建政','美欣','淑慧','文轩','文杰','欣源','忠林','榕润','欣汝','慧嘉','新建','建林','亦菲','林','冰洁','佳欣','涵涵','禹辰'];
        $realname = $xing[array_rand($xing)] . $ming[array_rand($ming)];
}
return $xing[array_rand($xing)] . $ming[array_rand($ming)]
}  

从关联表里面,随机读取一个ID,填入到系统表里面。比如A用户随机购买(1-100 ID里面的任意一个商品) B在模拟用户订单的时候,需要去读取商品库的ID信息表,需要使用到mysql的 select id from product order by rand() limit 1 随机读取仓库里面的一条数据信息。模拟用户下各种订单相关信息。

随机短语或者简单文章生成: 类似标题,乱句子(纯粹凑字数时候的使用)

  function generateRandomChinese($length = 1) {
        $commonChineseCharacters = [
            "的", "一", "是", "在", "不", "了", "有", "和", "就", "他","安","全","交","同",
            "通","新","问","温","文","测","题"."目","教","育","考","试"
        ];
        $randomChinese = '';
        for ($i = 0; $i < $length; $i++) {
            // 从常用汉字数组中随机选择一个汉字
            $randomIndex = array_rand($commonChineseCharacters);
            $randomChinese .= $commonChineseCharacters[$randomIndex];
        }
        return $randomChinese;
    }

有意义的句子在线生成,需要接入chatGPT或者其他开放平台的AI根据短语的生成。这种更加的智能一些。类似帮我写一点关于 教育的新闻(生成之后,填入数据表里面,给你自动生成)。AI在PHP的搭建,这里以千帆为例子(chatGPT涉及到墙问题),因为只是需要我们辅助生成简单文本,并不需要很精确,也不需要运营,挂一个辅助助手即可。

首先需要申请一个apikey和secret。下面是我使用国内千帆写的小辅助助手:

class Aihelp {
    const API_KEY = "key"; //你申请到key
    const SECRET_KEY = "secret"; //填入你的secret key
    //你的回答提问 在后台我们可以辅助接入相关数据,让用户输入回答 我们接入前端 只需要输入这个词
    public function run($need) {
        if(!$need)  return "请输入需求";
        $curl = curl_init();
        curl_setopt_array($curl, array(
            CURLOPT_URL => "https://aip.baidubce.com/rpc/2.0/ai_custom/v1/wenxinworkshop/chat/ernie-tiny-8k?access_token={$this->getAccessToken()}",
            CURLOPT_TIMEOUT => 30,
            CURLOPT_RETURNTRANSFER => true,
            CURLOPT_SSL_VERIFYPEER  => false,
            CURLOPT_SSL_VERIFYHOST  => false,
            CURLOPT_CUSTOMREQUEST => 'POST',
            CURLOPT_POSTFIELDS =>'{"messages":[{"role":"user","content":"'.$need.'"}],"temperature":0.95,"top_p":0.7,"penalty_score":1}',
            CURLOPT_HTTPHEADER => array(
                'Content-Type: application/json'
            ),

        ));
        $response = curl_exec($curl);
        curl_close($curl);
        return $this->result($response);
    }
    //这个就是我们对外输出的结果,辅助我们写文案或者自动化生成一些内容的时候 会使用到
    public function result($response) {
        $rtn = json_decode($response,true);
        return $rtn['result'];
    }

    /**
     * 使用 AK,SK 生成鉴权签名(Access Token)
     * @return string 鉴权签名信息(Access Token)
     * token的有效日期是30天  可以将token缓存本地直接读取,29天的时候失效或者失效后重新获取
     */
    private function getAccessToken(){
        $curl = curl_init();
        $postData = array(
            'grant_type' => 'client_credentials',
            'client_id' => self::API_KEY,
            'client_secret' => self::SECRET_KEY
        );
        curl_setopt_array($curl, array(
            CURLOPT_URL => 'https://aip.baidubce.com/oauth/2.0/token',
            CURLOPT_CUSTOMREQUEST => 'POST',
            CURLOPT_SSL_VERIFYPEER  => false,
            CURLOPT_SSL_VERIFYHOST  => false,
            CURLOPT_RETURNTRANSFER => true,
            CURLOPT_POSTFIELDS => http_build_query($postData)
        ));
        $response = curl_exec($curl);
        curl_close($curl);
        $rtn = json_decode($response);
        return $rtn->access_token;
    }
}

$need = "你多大了"; //需求
$rtn = (new Aihelp())->run($need);
print_r($rtn);

在实际应用里面,我们只需要输入我们对应的需求,收到的回答,填入数据库。这样我们网站的基础内容,可以借助AI的生成快速的填充相关类似内容。后期还是需要调整,不过真实运营还是需要真实资料。

比如我的场景: 生成一门关于安全方面的课程名字,第二个需求是简单介绍下生成的课程信息,第三个内容生成一模拟的大纲。

逻辑关系的数据填充:
这种是最复杂的,要通过A表查询B表里面数据,然后判断逻辑读取C表数据,拼接生成某些条件字段,最后填入D表里面,中途经过N次中转,完成数据的相关生成。这种基本只能在写逻辑的时候写入。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大梁来了

千山万水总是情,打赏一块行不行

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

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

打赏作者

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

抵扣说明:

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

余额充值