使用python发生此类错误 ValueError: endog must be in the unit interval.

from functools import reduce
import pandas as pd
import statsmodels.api as sm
import numpy as np
from scipy.optimize import minimize

df = pd.read_csv("pheno.asd", sep="\s+", header=0)
gmat = np.loadtxt("test.agrm.mat_fmt")

X = np.array(df.loc[:, 'mean':'sex'], dtype=np.float64)
y = np.array(df.loc[:, 'trait'], dtype=np.float64)

logit = sm.Logit(y, X)

前几日,当我在调试这个程序的时候突然爆出了一个错误

我对 statsmodels 这个库使用的不多并没有反应出这个错误是什么

于是我问了神奇的度娘

我发现,并没有什么能一下子让我明白错误在哪的文章

于是我参照  python - 值错误 : endog must be in the unit interval - IT工具网 https://www.coder.work/article/1270243

这篇文章的一个解答其实是问题所在,但是我当时并不知道错在哪里,并没有找到很好的解决的办法

于是我去用excel分析了一下我的数据

 他出现了0 1 之外的数字

我使用 statsmodels 这个库是为了拟合逻辑回归的初值

我筛选查看的这一列是放入的表型

也就是 y = np.array(df.loc[:, 'trait'], dtype=np.float64)

当使用函数 logit = sm.Logit(y, X) 拟合的时候便会出现错误,当修改数据使其不会出现除了0 1 之外的数据,报错解决

 

 

 

这个错误通常是由于传递给函数的日期格式不正确造成的。month参数必须在1到12之间,否则就会出现这个错误。 如果您传递的日期格式是字符串,可以尝试按照正确的格式传递日期。例如,如果您想传递2022年5月的日期,可以使用"2022-05"这种格式。 如果您使用的是datetime.date对象,则可以使用对象的strftime方法将日期格式化为字符串,然后再传递给函数。 另外,如果您传递的日期是无效的,例如2月30日,也会导致这个错误的出现。在传递日期之前,最好检查一下日期是否有效。 以下是一个示例程序,用于检查日期是否有效,并将日期格式化为正确的格式: ```python import datetime def check_date(date_str): try: datetime.datetime.strptime(date_str, '%Y-%m-%d') return True except ValueError: return False def format_date(date_str): if check_date(date_str): return date_str else: date_obj = datetime.datetime.strptime(date_str, '%Y%m%d') return date_obj.strftime('%Y-%m') # 示例:将202205格式的日期格式化为2022-05格式 date_str = '202205' formatted_date = format_date(date_str) print(formatted_date) ``` 在这个示例程序中,我们定义了两个函数:check_date和format_date。check_date函数用于检查日期是否有效,如果有效则返回True,否则返回False。format_date函数用于将日期格式化为正确的格式,如果传递的日期格式为"YYYY-MM-DD",则直接返回,否则将日期格式化为"YYYY-MM"的格式。 在进行日期格式化之前,我们先调用check_date函数检查日期是否有效。如果日期无效,则抛出ValueError异常。如果日期有效,则使用datetime库的strptime函数将日期字符串转换为datetime.datetime对象,然后使用对象的strftime方法将日期格式化为正确的格式。 您可以参考这个示例程序,根据您的实际情况进行调整和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值