欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Python的Django框架中生成CSV文件的方法

 更新時(shí)間:2015年07月22日 14:48:44   投稿:goldensun  
這篇文章主要介紹了在Python的Django框架中生成CSV文件的方法,利用到了Python下的csv模塊,需要的朋友可以參考下

CSV 是一種簡(jiǎn)單的數(shù)據(jù)格式,通常為電子表格軟件所使用。 它主要是由一系列的表格行組成,每行中單元格之間使用逗號(hào)(CSV 是 逗號(hào)分隔數(shù)值(comma-separated values) 的縮寫)隔開。例如,下面是CSV格式的“不守規(guī)矩”的飛機(jī)乘客表。

Year,Unruly Airline Passengers
1995,146
1996,184
1997,235
1998,200
1999,226
2000,251
2001,299
2002,273
2003,281
2004,304
2005,203
2006,134
2007,147

備注

前面的列表包含真實(shí)數(shù)據(jù)。 這些數(shù)據(jù)來(lái)自美國(guó) 聯(lián)邦航空管理局。

CSV格式盡管看起來(lái)簡(jiǎn)單,卻是全球通用的。 但是不同的軟件會(huì)生成和使用不同的 CSV 的變種,在使用上會(huì)有一些不便。 幸運(yùn)的是, Python 使用的是標(biāo)準(zhǔn) CSV 庫(kù), csv ,所以它更通用。

因?yàn)?csv 模塊操作的是類似文件的對(duì)象,所以可以使用 HttpResponse 替換:

import csv
from django.http import HttpResponse

# Number of unruly passengers each year 1995 - 2005. In a real application
# this would likely come from a database or some other back-end data store.
UNRULY_PASSENGERS = [146,184,235,200,226,251,299,273,281,304,203]

def unruly_passengers_csv(request):
  # Create the HttpResponse object with the appropriate CSV header.
  response = HttpResponse(mimetype='text/csv')
  response['Content-Disposition'] = 'attachment; filename=unruly.csv'

  # Create the CSV writer using the HttpResponse as the "file."
  writer = csv.writer(response)
  writer.writerow(['Year', 'Unruly Airline Passengers'])
  for (year, num) in zip(range(1995, 2006), UNRULY_PASSENGERS):
    writer.writerow([year, num])

  return response

代碼和注釋可以說(shuō)是很清楚,但還有一些事情需要特別注意:

  •     響應(yīng)返回的是 text/csv MIME類型(而非默認(rèn)的 text/html )。這會(huì)告訴瀏覽器,返回的文檔是CSV文件。
  •     響應(yīng)會(huì)有一個(gè)附加的 Content-Disposition 頭部,它包含有CSV文件的文件名。 這個(gè)頭部(或者說(shuō),附加部分)會(huì)指示瀏覽器彈出對(duì)話框詢問(wèn)文件存放的位置(而不僅僅是顯示)。 這個(gè)文件名是任意的。 它會(huì)顯示在瀏覽器的另存為對(duì)話框中。
  •     要在HttpResponse指定頭部信息,只需把HttpResponse當(dāng)做字典使用就可以了。
  •     與創(chuàng)建CSV的應(yīng)用程序界面(API)掛接是很容易的: 只需將 response 作為第一個(gè)變量傳遞給 csv.writer 。 csv.writer 函數(shù)需要一個(gè)文件類的對(duì)象, HttpResponse 正好能達(dá)成這個(gè)目的。
  •     調(diào)用 writer.writerow ,并且傳遞給它一個(gè)類似 list 或者 tuple 的可迭代對(duì)象,就可以在 CSV 文件中寫入一行。
  •     CSV 模塊考慮到了引用的問(wèn)題,所以您不用擔(dān)心逸出字符串中引號(hào)和逗號(hào)。 只要把信息傳遞給 writerow() ,它會(huì)處理好所有的事情。

在任何需要返回非 HTML 內(nèi)容的時(shí)候,都需要經(jīng)過(guò)以下幾步: 創(chuàng)建一個(gè) HttpResponse 響應(yīng)對(duì)象(需要指定特殊的 MIME 類型),它它傳給需要處理文件的函數(shù),然后返回這個(gè)響應(yīng)對(duì)象。

相關(guān)文章

  • Python實(shí)現(xiàn)輕松提取Word中的圖片

    Python實(shí)現(xiàn)輕松提取Word中的圖片

    Microsoft Word是廣泛用于文檔編輯和處理的工具,有時(shí)候,可能需要從Word文檔中提取所有的圖片,以進(jìn)行后續(xù)的處理或分析,本文主要介紹了如何使用Python實(shí)現(xiàn)這一操作,需要的可以參考下
    2024-01-01
  • OpenCV實(shí)現(xiàn)對(duì)象跟蹤的方法

    OpenCV實(shí)現(xiàn)對(duì)象跟蹤的方法

    OpenCV 是一個(gè)很好的處理圖像和視頻的工具,本文主要介紹了OpenCV 進(jìn)行對(duì)象跟蹤,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 代碼總結(jié)Python2 和 Python3 字符串的區(qū)別

    代碼總結(jié)Python2 和 Python3 字符串的區(qū)別

    在本篇文章里小編給大家整理的是一篇關(guān)于Python2 和 Python3 字符串的區(qū)別以及實(shí)例代碼,需要的朋友們學(xué)習(xí)下。
    2020-01-01
  • 多場(chǎng)景下的Pandas使用技巧分享

    多場(chǎng)景下的Pandas使用技巧分享

    這篇文章主要介紹了多場(chǎng)景下的Pandas使用技巧,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Python values()與itervalues()的用法詳解

    Python values()與itervalues()的用法詳解

    今天小編就為大家分享一篇Python values()與itervalues()的用法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • python裝飾器類方法classmethod的使用場(chǎng)景

    python裝飾器類方法classmethod的使用場(chǎng)景

    這篇文章主要為大家介紹了python裝飾器類方法classmethod的使用場(chǎng)景,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 談?wù)刾ython中GUI的選擇

    談?wù)刾ython中GUI的選擇

    本篇文章給大家詳細(xì)分析了一個(gè)在python編程中GUI的選擇相關(guān)知識(shí)點(diǎn),如果大家對(duì)此有興趣可以閱讀參考下。
    2018-03-03
  • python 隨機(jī)密碼生成器的實(shí)現(xiàn)示例

    python 隨機(jī)密碼生成器的實(shí)現(xiàn)示例

    隨機(jī)密碼生成器是一種非常有用的工具,它可以幫助我們生成隨機(jī)的、復(fù)雜的密碼,提高我們的賬戶安全性,本文就來(lái)介紹一下python 隨機(jī)密碼生成器的實(shí)現(xiàn)示例,感興趣的可以了解一下
    2023-11-11
  • Python 如何測(cè)試文件是否存在

    Python 如何測(cè)試文件是否存在

    這篇文章主要介紹了Python 如何測(cè)試文件是否存在,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • Python小程序之在圖片上加入數(shù)字的代碼

    Python小程序之在圖片上加入數(shù)字的代碼

    這篇文章主要介紹了Python小程序之在圖片上加入數(shù)字的代碼,這個(gè)是小編今天練手的小程序,代碼簡(jiǎn)單易懂,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論