在Django 1.3中,用户上传一个“hello world”应用程序所需的最少示例代码是什么?


当前回答

它可能会帮助你: 在models.py中创建一个文件字段

上传文件(在admin.py中):

def save_model(self, request, obj, form, change):
    url = "http://img.youtube.com/vi/%s/hqdefault.jpg" %(obj.video)
    url = str(url)

    if url:
        temp_img = NamedTemporaryFile(delete=True)
        temp_img.write(urllib2.urlopen(url).read())
        temp_img.flush()
        filename_img = urlparse(url).path.split('/')[-1]
        obj.image.save(filename_img,File(temp_img)

并在模板中使用该字段。

其他回答

一般来说,当你试图“只是得到一个工作示例”时,最好是“开始写代码”。这里没有代码来帮助你,所以这使得回答问题对我们来说更加困难。

如果你想抓取一个文件,你需要在一个html文件中找到这样的东西:

<form method="post" enctype="multipart/form-data">
    <input type="file" name="myfile" />
    <input type="submit" name="submit" value="Upload" />
</form>

这将给你一个浏览按钮,一个上传按钮来开始操作(提交表单),并注意enctype以便Django知道给你请求。文件

在某个视图中,你可以访问该文件

def myview(request):
    request.FILES['myfile'] # this is my file

在文件上传文档中有大量的信息

我建议您彻底阅读该页面,然后开始编写代码——当它不起作用时,再返回示例和堆栈跟踪。

它可能会帮助你: 在models.py中创建一个文件字段

上传文件(在admin.py中):

def save_model(self, request, obj, form, change):
    url = "http://img.youtube.com/vi/%s/hqdefault.jpg" %(obj.video)
    url = str(url)

    if url:
        temp_img = NamedTemporaryFile(delete=True)
        temp_img.write(urllib2.urlopen(url).read())
        temp_img.flush()
        filename_img = urlparse(url).path.split('/')[-1]
        obj.image.save(filename_img,File(temp_img)

并在模板中使用该字段。

我也有类似的要求。网上的大多数例子都要求创建模型和表单,我不想使用。这是我的最终代码。

if request.method == 'POST':
    file1 = request.FILES['file']
    contentOfFile = file1.read()
    if file1:
        return render(request, 'blogapp/Statistics.html', {'file': file1, 'contentOfFile': contentOfFile})

在HTML中我写了:

{% block content %}
    <h1>File content</h1>
    <form action="{% url 'blogapp:uploadComplete'%}" method="post" enctype="multipart/form-data">
         {% csrf_token %}
        <input id="uploadbutton" type="file" value="Browse" name="file" accept="text/csv" />
        <input type="submit" value="Upload" />
    </form>
    {% endblock %}

下面是显示文件内容的HTML:

{% block content %}
    <h3>File uploaded successfully</h3>
    {{file.name}}
    </br>content = {{contentOfFile}}
{% endblock %}

我必须说我发现django的文档令人困惑。 还有一个最简单的例子,为什么要提到表单? 我在views.py中工作的例子是:-

for key, file in request.FILES.items():
    path = file.name
    dest = open(path, 'w')
    if file.multiple_chunks:
        for c in file.chunks():
            dest.write(c)
    else:
        dest.write(file.read())
    dest.close()

html文件看起来像下面的代码,尽管这个例子只上传了一个文件,保存文件的代码处理许多:-

<form action="/upload_file/" method="post" enctype="multipart/form-data">{% csrf_token %}
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<br />
<input type="submit" name="submit" value="Submit" />
</form>

这些示例不是我的代码,它们是从我找到的其他两个示例中选取的。 我是一个相对初学者django,所以很可能我错过了一些关键点。

不确定这种方法是否有任何缺点,但更小,在views.py中:

entry = form.save()

# save uploaded file
if request.FILES['myfile']:
    entry.myfile.save(request.FILES['myfile']._name, request.FILES['myfile'], True)