python - 预期的 str、bytes 或 os.PathLike 对象,而不是 InMemoryUploadedFile

标签 python django ncbi ete3

我有一个方法来读取 Newick 文件并在 Django 框架中返回一个字符串,如下所示:

def handle_uploaded_file(f):
    output = " "
    for chunk in f.chunks():
        output += chunk.decode('ascii')
    return output.replace("\n", "").replace("\r", "")


def post(self, request):
    form = HomeForm(request.POST, request.FILES)
    if form.is_valid():
        input = handle_uploaded_file(request.FILES['file'])
        treeGelezen = Tree(input, format=1)
        script, div = mainmain(treeGelezen)
        form = HomeForm()
    args = {'form': form, 'script': script, 'div': div}
    return render(request, self.template_name, args)

这适用于普通的 Newick 文件,但我也有一些文件在文件开头有一个字符串。我正在尝试创建另一种方法来检查文件前面是否有以下字符串(某些文件中就是这种情况):“newick;”并删除该字符串(如果找到)。它在本地工作,但我似乎无法合并它们。这是它在本地的样子:

def removeNewick(tree_with_newick):
    for x in tree_with_newick:
        if x.startswith('newick;'):
            print('')
    return x


filepath = "C:\\Users\\msi00\\Desktop\\ncbi-taxanomy.tre"
tree_with_newick = open(filepath)
tree = Tree(newick=removeNewick(tree_with_newick), format=1)

当我在 python 中指定路径时效果很好,所以我尝试在 Django 中将它们组合起来,如下所示:

def handle_uploaded_file(f):
    tree_with_newick = open(f)
    for x in tree_with_newick:
        if x.startswith('newick;'):
            print('')
    return cutFile(x)


def cutFile(f):
    output = " "
    for chunk in f.chunks():
        output += chunk.decode('ascii')
    return output.replace("\n", "").replace("\r", "")


def post(self, request):
    form = HomeForm(request.POST, request.FILES)
    if form.is_valid():
        input = handle_uploaded_file(request.FILES['file'])
        treeGelezen = Tree(input, format=1)
        script, div = mainmain(treeGelezen)
        form = HomeForm()
    args = {'form': form, 'script': script, 'div': div}
    return render(request, self.template_name, args)

这不起作用,并且会出现以下错误:

expected str, bytes or os.PathLike object, not InMemoryUploadedFile

我已经研究了两天了,但无法弄清楚为什么会弹出错误。

最佳答案

发生错误的原因是函数handle_uploaded_file(f)正在尝试打开一个已打开的文件。

request.FILES['file']的值是一个InMemoryUploadedFile,可以像普通文件一样使用。您无需再次打开它。

要修复此问题,只需删除尝试打开文件的行即可:

def handle_uploaded_file(f):
    for x in f:
        if x.startswith('newick;'):
            print('')
    return cutFile(x)

关于python - 预期的 str、bytes 或 os.PathLike 对象,而不是 InMemoryUploadedFile,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50638374/

相关文章:

python - 如何从当前应用程序运行独立应用程序?

python - 在阅读之前懒惰地过滤文件

javascript - 如何解决超链接的非常大的 URL 问题...使用 jQuery 或 Javascript 在后面调用任何 perl、php 等脚本

python - 为什么我得到 BioPython HTTPError : HTTP Error 400: Bad Request when I use Esearch and Efetch

python - 手动删除pip包后如何删除

python - 简单的 CSV 词法分析器

python - NameError:名称 '' 未定义

python - 坚持官方 Django 教程

javascript - 当我在子页面时没有激活导航父页面

r - 用户定义的函数在 dplyr 管道中不起作用