我正在尝试从 Excel 工作表中检索字符串并将其拆分为单词,然后打印它或将其写回到新字符串中,但是当使用 pandas 检索数据并尝试拆分它时,会出现错误,提示 dataframe does' t 支持分割功能
Excel 工作表中有这一行:
我期望并输出如下:
import numpy
import pandas as pd
df = pd.read_excel('eng.xlsx')
txt = df
x = txt.split()
print(x)
AttributeError: 'DataFrame' object has no attribute 'split'
最佳答案
那是因为您正在 DataFrame 上应用 split()
函数,而这是不可能的。
import pandas as pd
import numpy as np
def append_nan(x, max_len):
"""
Function to append NaN value into a list based on a max length
"""
if len(x) < max_len:
x += [np.nan]*(max_len - len(x))
return x
# I define here a dataframe for the example
#df = pd.DataFrame(['This is my first sentence', 'This is a second sentence with more words'])
df = pd.read_excel('your_file.xlsx', index=None, header=None)
col_names = df.columns.values.tolist()
df_output = df.copy()
# Split your strings
df_output[col_names[0]] = df[col_names[0]].apply(lambda x: x.split(' '))
# Get the maximum length of all yours sentences
max_len = max(map(len, df_output[col_names[0]]))
# Append NaN value to have the same number for all column
df_output[col_names[0]] = df_output[col_names[0]].apply(lambda x: append_nan(x, max_len))
# Create columns names and build your dataframe
column_names = ["word_"+str(d) for d in range(max_len)]
df_output = pd.DataFrame(list(df_output[col_names[0]]), columns=column_names)
# Then you can save it
df_output.to_excel('output.xlsx')
关于python - 如何将数据框列的文本拆分为多列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58819435/