如何将数据框列的文本分成多列?

时间:2019-11-12 13:07:22

标签: python excel pandas dataframe

我正在尝试从Excel工作表中检索一个字符串并将其拆分为单词,然后将其打印或写回新的字符串中,但是当使用pandas检索数据并尝试对其进行拆分时,会出现错误,提示数据框没有t支持拆分功能

excel工作表中包含以下行:

enter image description here

我希望这样输出:

enter image description here

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'

1 个答案:

答案 0 :(得分:2)

那是因为您要在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')