鱼C论坛

 找回密码
 立即注册
查看: 475|回复: 17

我用这种方法弄的DF怎么有几行空行

[复制链接]
发表于 2024-4-28 19:03:12 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
self.late_less_df = pd.DataFrame(None,index=["姓名","工作地点","岗位","20m内迟到","20m内迟到分钟"]),,,,这个是我建立的空的DF

——————————————————————————————————————
这个是我遍历到的符合条件要加入上面这个DF里面的信息,并新增到DF里面去,,

self.late_less_series = pd.Series([self.name, self.place, self.post, 1, int(self.minute)],index=["姓名","工作地点","岗位","20m内迟到","20m内迟到分钟"])
self.late_less_df = self.late_less_df.append(self.late_less_series,ignore_index=True)


最后生成的DF输出后为什么总有前面五行是空行
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-4-28 19:03:28 | 显示全部楼层
在使用`self.late_less_df.append(self.late_less_series, ignore_index=True)`将`self.late_less_series`添加到`self.late_less_df`时,会出现前面几行是空行的问题。这是因为`ignore_index=True`会忽略原始索引,并重新为新添加的行生成一个新的整数索引。

解决办法是在创建`self.late_less_df`时,设置一个初始化的空DataFrame,并指定列名,如下所示:
self.late_less_df = pd.DataFrame(columns=['col1', 'col2'])  # 替换'col1', 'col2'为实际的列名

# 然后将series添加到dataframe
self.late_less_series = pd.Series([...])  # 替换[...]为实际的series数据
self.late_less_df = self.late_less_df.append(self.late_less_series, ignore_index=True)

这样就不会出现前面几行是空行的问题了。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:08:10 | 显示全部楼层
FishC 发表于 2024-4-28 19:03
在使用`self.late_less_df.append(self.late_less_series, ignore_index=True)`将`self.late_less_series` ...

self.late_less_df = pd.DataFrame(None,columns=["姓名","工作地点","岗位","20m内迟到","20m内迟到分钟"])

self.late_less_series = pd.Series([self.name, self.place, self.post, 1, int(self.minute)])
self.late_less_df = self.late_less_df.append(self.late_less_series,ignore_index=True)

————————————————————
你说的是不是这样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:08:25 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:08
self.late_less_df = pd.DataFrame(None,columns=)

...


是的,你的代码是正确的。通过在创建`self.late_less_df`时指定列名,可以避免前面几行是空行的问题。同时,使用`ignore_index=True`参数可以重新生成一个新的整数索引,确保所有行都按顺序排列。

所以你的代码应该是没有前面几行是空行的问题的:
self.late_less_df = pd.DataFrame(columns=[])  # 在这里替换[]为实际的列名

self.late_less_series = pd.Series()  # 替换为实际的series数据
self.late_less_df = self.late_less_df.append(self.late_less_series, ignore_index=True)

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:12:07 | 显示全部楼层
FishC 发表于 2024-4-28 19:08
是的,你的代码是正确的。通过在创建`self.late_less_df`时指定列名,可以避免前面几行是空行的问题。 ...

但是这样做前面又多了五列空列,我前面命名的columns,全部下面没有数据,然后每一条SERIES的信息都新建在了第6列后面
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:12:21 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:12
但是这样做前面又多了五列空列,我前面命名的columns ...


抱歉,我之前的回答有误。确实使用`pd.DataFrame(columns=)`会创建空的列。为了避免这个问题,你可以通过以下方法创建一个没有任何数据或列的空DataFrame:
self.late_less_df = pd.DataFrame()

然后,将series添加到DataFrame时,指定`ignore_index=True`参数,以确保新的行按顺序排列,并且索引会自动调整:
self.late_less_series = pd.Series()  # 替换为实际的series数据
self.late_less_df = self.late_less_df.append(self.late_less_series, ignore_index=True)

这样就可以避免空列的问题和将数据添加到第六列的问题了。抱歉给你带来的困惑,希望这次的解答能够帮到你。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:14:06 | 显示全部楼层
FishC 发表于 2024-4-28 19:12
抱歉,我之前的回答有误。确实使用`pd.DataFrame(columns=)`会创建空的列。为了避免这个问题,你可以通 ...

那这样又没有了列名
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:14:27 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:14
那这样又没有了列名


非常抱歉之前的回答不准确,给你带来了困惑。在创建空DataFrame时,如果没有实际的列名,可以通过以下方法创建一个没有任何数据但有列名的空DataFrame:
self.late_less_df = pd.DataFrame(columns=['col1', 'col2', ...])  # 根据实际情况添加列名

然后,将series添加到DataFrame时,指定`ignore_index=True`参数,以确保新的行按顺序排列,并且索引会自动调整:
self.late_less_series = pd.Series()  # 替换为实际的series数据
self.late_less_df = self.late_less_df.append(self.late_less_series, ignore_index=True)

这样就可以避免空列的问题,并保留具有列名的空DataFrame。非常抱歉给您带来的困扰,希望这次的解答能够解决您的问题。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:21:36 | 显示全部楼层
FishC 发表于 2024-4-28 19:14
非常抱歉之前的回答不准确,给你带来了困惑。在创建空DataFrame时,如果没有实际的列名,可以通过以下 ...

那不是又一样了,又是会空了几列出来,,,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:21:45 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:21
那不是又一样了,又是会空了几列出来,,,


非常抱歉之前的回答仍然不准确。为了避免出现空列的问题,你可以使用以下方法创建一个没有任何数据但有列名的空DataFrame:
self.late_less_df = pd.DataFrame(columns=['col1', 'col2'])  # 根据实际情况添加列名

然后,将Series添加到DataFrame时,不需要使用`ignore_index=True`参数。这样新的行将按照其原始索引添加,并且不会出现空行的问题:
self.late_less_series = pd.Series()  # 替换为实际的Series数据
self.late_less_df = self.late_less_df.append(self.late_less_series)

这样就可以保留具有列名的空DataFrame,并且在添加Series数据时不会出现空行或空列的问题。非常抱歉给您带来的困扰,希望这次的解答能够解决您的问题。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:25:31 | 显示全部楼层
FishC 发表于 2024-4-28 19:21
非常抱歉之前的回答仍然不准确。为了避免出现空列的问题,你可以使用以下方法创建一个没有任何数据但有 ...

我最烦你这个机器人罗圈的回答问题,A问题用B方案,然后产生B问题~~~接着就是用C方案解决B问题~再产生C问题~~~然后用A方案解决C问题~再产生A问题~~~~~~~循环往复,,,问半天问不出个完美解决方案来
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:25:46 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:25
我最烦你这个机器人罗圈的回答问题,A问题用B方案,然 ...


非常抱歉给您带来困扰。我理解您对问题的迭代回答感到不满意。让我尝试为您提供一个更加完美的解决方案。

在创建空的DataFrame时,可以使用如下方法:

self.late_less_df = pd.DataFrame(columns=)  # 根据实际情况添加列名

接着,将Series数据按行添加到DataFrame中,但要先将Series转换为DataFrame,再使用`concat`方法进行合并:

self.late_less_series = pd.Series()  # 替换为实际的Series数据
self.late_less_df = pd.concat([self.late_less_df, self.late_less_series.to_frame().T], ignore_index=True)

使用`self.late_less_series.to_frame().T`可以将Series转换为DataFrame,并确保每个Series都作为新行添加到DataFrame中。最后,设置`ignore_index=True`参数可以重新生成连续的索引。

这样,您就可以得到一个没有空行和空列的DataFrame,其中包含了所有Series数据。再次对之前的回答给您的困惑表示诚挚的歉意,希望这个解决方案能够满足您的需求。如果还有其他问题,请随时向我提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:31:10 | 显示全部楼层
FishC 发表于 2024-4-28 19:25
非常抱歉给您带来困扰。我理解您对问题的迭代回答感到不满意。让我尝试为您提供一个更加完美的解决方案 ...

没用,columns那几列又跑后面去了,空列现在变成再后面了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:31:24 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:31
没用,columns那几列又跑后面去了,空列现在变成再后 ...


非常抱歉我之前的回答仍然没有解决您的问题。让我尝试以一种更简单和直接的方式来解释如何创建一个没有空列的空DataFrame,并将Series数据正确添加到其中。

首先,创建一个空的DataFrame,只指定列名而不传入具体的数据:
self.late_less_df = pd.DataFrame(columns=['col1', 'col2', 'col3'])  # 根据实际情况添加列名

然后,将Series数据转换为DataFrame形式:
self.late_less_series = pd.Series(['data1', 'data2', 'data3'])  # 替换为实际的Series数据
self.late_less_df = self.late_less_df.append(pd.DataFrame([self.late_less_series], columns=self.late_less_df.columns), ignore_index=True)

在此方法中,我们首先将Series数据转换为DataFrame,并通过`columns=self.late_less_df.columns`确保新的DataFrame有与原始空DataFrame相同的列名。然后,使用`append`方法将该DataFrame添加到原始空DataFrame中,并使用`ignore_index=True`参数重新生成索引。

这样,您将获得一个没有空列的空DataFrame,并且成功将Series数据按行添加到其中。希望这次的解答能够解决您的问题。如果还有其他问题,请随时向我提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-28 19:32:32 | 显示全部楼层
FishC 发表于 2024-4-28 19:31
非常抱歉我之前的回答仍然没有解决您的问题。让我尝试以一种更简单和直接的方式来解释如何创建一个没有 ...

我简直不应该在你这里浪费时间,我干脆用我一开始的方法弄完了到最后再去除空白行更好点
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-28 19:32:52 | 显示全部楼层
laiyuanjie 发表于 2024-04-28 19:32
我简直不应该在你这里浪费时间,我干脆用我一开始的方 ...


非常抱歉之前的回答没有解决您的问题。如果您觉得使用最初的方法完成后再去除空白行更好,请按照您的计划进行操作。以下是一种可能的解决方案:

首先,按照您最初的方法创建一个空的DataFrame,并将Series数据添加到其中:
self.late_less_df = pd.DataFrame(None, columns=)  # 根据实际情况添加列名

self.late_less_series = pd.Series()  # 替换为实际的Series数据
self.late_less_df = self.late_less_df.append(self.late_less_series, ignore_index=True)

然后,在完成所有操作后,使用`dropna()`方法去除空白行(缺失值):
self.late_less_df = self.late_less_df.dropna()

这样,您将获得在最初的DataFrame中添加了Series数据并且不包含空白行的结果。非常抱歉给您带来的困扰。如果还有其他问题,请随时向我提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-29 12:48:02 | 显示全部楼层


是不是你程序或读取的数据本身原因就导致了有五行空数据?

你试试再插入数据之前,打印一下 [self.name, self.place, self.post, 1, int(self.minute)]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-5-11 20:48:01 | 显示全部楼层
晕死了,,今天晚上被我突然间试出来了,特意回来分享一下,,,

就是在建立DF的时候,要把columns打进去,如下:
self.late_less_df = pd.DataFrame(None,columns=["姓名","工作地点","岗位","20m内迟到","20m内迟到分钟"])

——————————————————————————————————————
然后要添加进上面那个DF的这个series ,里面的弄成index,如下:

self.late_less_series = pd.Series([self.name, self.place, self.post, 1, int(self.minute)],index=["姓名","工作地点","岗位","20m内迟到","20m内迟到分钟"])


----------------------------------------------------------------------------------------------------------------------------------------------

这样就可以完美的把series添加进DF里面,而且列名一次性全部设置好,且不会出现空行空列的情况,也不需要后续去设置列名

self.late_less_df = self.late_less_df.append(self.late_less_series,ignore_index=True)


我原先错就错在设置空的DF,和添加新的series的时候,要么两个都是通过index去设置,要么两个都是通过columns去设置,于是就会出现我前面帖子里所说的,有五行或五列空值,给有需求到的鱼油提个醒呵
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-23 04:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表