如何从位于指定文件夹中的一个文件(具有任何文件名)创建 pandas 数据框?

How to create a pandas dataframe from one file (with any file name) located in a specified folder?

从位于指定文件夹中的任意文件名的一个文件创建 pandas 数据框的最佳方法是什么?

我已经使用了 pathlib,但由于输出数据帧没有给我任何东西,所以它不太有效。

from pathlib import Path
import pandas as pd

pth = r'C:\Users\HP\Desktop\IBM\New folder'
fle = Path(pth).glob('*.tsv')

someDf = pd.DataFrame(fle)
someDf

编辑:

我也尝试执行以下操作,但输出数据框将所有列合并为一列,并用反斜杠分隔。我该如何解决这个问题?

from pathlib import Path
import pandas as pd

pth = r'C:\Users\HP\Desktop\IBM\New folder'
fle = Path(pth).glob('*.tsv')

dfs = []
for filename in fle:
    dfs.append(pd.read_csv(filename))

dfs1 = pd.concat(dfs)
dfs1.head()

我这样做的方式似乎很复杂。有更简单的方法吗?

我找到的解决方案如下。我错过了 pd.read_csv() 中的 sep 参数。

from pathlib import Path
import pandas as pd

pth = r'C:\Users\HP\Desktop\IBM\New folder'
fle = Path(pth).glob('*.tsv')

dfs = []
for filename in fle:
    dfs.append(pd.read_csv(filename, sep='\t'))

dfs1 = pd.concat(dfs)
dfs1.head()

请尝试:

from pathlib import Path
import pandas as pd
import os
pth = r'C:\Users\HP\Desktop\IBM\New folder'
for file_ in os.listdir(pth):
    h=os.path.join(pth, file_)
    #print (h)
someDf = pd.read_csv(h)
someDf

尝试

from glob import glob
files = glob('C:\Users\HP\Desktop\IBM\New folder\*.tsv')
if len(files) == 1:
    dfs = pd.read_csv(files[0], sep='\t')
else:
    dfs = pd.concat([pd.read_csv(file, sep='\t') for file in files])