亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

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

系統(tǒng) 2265 0

CSV 是一種簡單的數(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ù)來自美國 聯(lián)邦航空管理局。

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

因?yàn)?csv 模塊操作的是類似文件的對象,所以可以使用 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


          

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

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

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


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦?。?!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久婷婷婷 | 欧美www视频 | 99热最新网站 | 草草影院1 | 亚洲欧美日韩图片 | 五月婷婷综合激情 | jizz成熟丰满老女人 | 亚洲一区二区视频在线观看 | 国产成人精品午夜免费 | 色综合天天综合网站中国 | 久久美女 | 99久久久国产精品免费牛牛四川 | 四虎视频在线 | 精品亚洲欧美中文字幕在线看 | 毛片免费观看网址 | 私人影院在线免费观看 | 欧美午夜毛片a级在线 | 天堂成人精品视频在线观 | 就操视频 | 天天拍夜夜添久久精品中文 | 亚洲免费在线看 | 一级成人毛片免费观看 | 性夜影院爽黄a爽免费看网站 | 国产欧美亚洲三区久在线观看 | 亚洲小视频网站 | 成人欧美午夜视频毛片 | 精品不卡 | 久久久日本精品一区二区三区 | 中文字幕日韩一区二区不卡 | 成人久久久久久 | 欧美大狠狠大臿蕉香蕉大视频 | aaa一级最新毛片 | 午夜影院普通 | 久久免费观看视频 | 伊人色播 | 乱人伦视频69 | 一级特黄aaa大片 | 亚洲一区二区日韩欧美gif | 成人www视频 | 操一操| 牛牛影视免费观看成人 |