PHP开发中遇到的小问题(0与字符串比较)-L001

变量比较之0与字符串比较

今天用Kohana框架写一个计划任务,登录第三方系统抓取数据,因此需要登录。

登录接口返回的结果是:成功 {"code":0,"message":""} ,失败{"code":"user_id","message":"错误信息"}

编写程序调用登录接口,读取并json_decode解码

程序中这样写登录成功失败的判断:

$login_result =  $this->login();
$login_result = json_decode($login_result);
if( 0 == $login_result["code"]){
    echo '登录成功!';
}else{
    echo '登录失败!';
}

因为PHP语言是弱类型的,不同类型的变量比较时会对变量自动进行转换,这个 0是integer类型,所以 $login_result["code"] 自动转换为integer,其值由字符串变成0。所以这个比较永远是true。

那么这里应该怎么处理呢?很简单,只需要用全等号(===)比较,如下:

if( 0 === $login_result["code"]){

只有类型和值都相同比较结果才会等于true。

因此在比较不同类型的变量的时候一定要注意变量类型的自动转换,还有注意你的变量的类型是否书写正确,如0与“0”。



这个函数 `xlsx_L001_L008` 可能是某个项目的辅助函数,用于处理和操作Excel数据。其输入参数包括: 1. `df_A_0_1`: 这是一个Pandas DataFrame对象,可能是从其他源获取的原始数据或者经过初步处理的数据集。 2. `file_name_step3_A0`, `file_name_step3_A1`: 这两个参数可能是字符串,表示目标Excel文件的名称,其后缀步长可能代表不同的阶段或者是针对不同部分的数据。 3. `dict_A0`, `dict_A1`: 这两个可能是字典类型,可能存储了一些元数据、规则或者映射信息,用于指导如何对DataFrame进行进一步操作,比如筛选、分类等。 函数的具体功能未在给出的上下文详细说明,但从名字推测,它可能涉及到将数据集按照某种规则或者基于 `dict_A0` 和 `dict_A1` 的信息分为两部分(A0和A1),然后分别写入到对应的Excel文件 `file_name_step3_A0` 和 `file_name_step3_A1` ,可能是为了进行更精细的数据分析或组织。 由于缺少具体的实现细节,可以假设这个函数可能执行类似这样的操作: ```python # 省略了具体实现的细节 for key in dict_A0.keys(): filtered_df = df_A_0_1[df_A_0_1[key] == dict_A0[key]] filtered_df.to_excel(file_name_step3_A0, sheet_name=key, index=False) for key in dict_A1.keys(): filtered_df = df_A_0_1[df_A_0_1[key] == dict_A1[key]] filtered_df.to_excel(file_name_step3_A1, sheet_name=key, index=False) ``` 完成上述操作后,每个键值对会生成一个新的工作表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值