在Django中生成TSV文件

Ste*_*en 2 django

我想从车辆列表中生成TSV文件....我还将对数据进行一些转换,例如,如果传输的值是"自动",那么此值将呈现为"A"或里程数以英里为单位,然后将此值乘以1.6.

最好的方法是什么?

UPDATE

好的......所以我写了如下脚本:

from django.conf import settings
import myapp.settings
setup_environ(myapp.settings)

from django.db import models
from myapp.vehicles.models import Vehicle

import csv

data = Vehicle.objects.all().exclude(status__status='Internal Use').
   exclude(status__status='Sold').order_by('-common_vehicle__year',
   'common_vehicle__series__model__manufacturer__manufacturer',
   'common_vehicle__series__model__manufacturer__manufacturer_popularity')


vehicles = csv.writer(open('cars.csv', 'w'), delimiter='\t')
vehicles.writerow(["VIN","Stock","Year","Make","Model",
    "TrimPackage","Transmission","DriveType","Odometer","OdometerType",
    "Doors","BodyStyle","EngineType","Exterior","Interior","Condition",
    "Certified","FuelType","Price"])
for vehicle in data:
  vehicles.writerow(["1130","26919",vehicle.vin,vehicle.stock_number,
  vehicle.common_vehicle.year.year,
  vehicle.common_vehicle.series.model.manufacturer.manufacturer,
  vehicle.common_vehicle.series.model.model,vehicle.common_vehicle.series.series,
  transmission,vehicle.common_vehicle.drive_train.drive_train,
  vehicle.odometer_reading,"KM",vehicle.common_vehicle.body_style.doors,
  body_style,engine_type,vehicle.exterior_colour.exterior_colour,
  vehicle.interior_colour.interior_colour,"E","Y",fuel_type,"0"])
Run Code Online (Sandbox Code Playgroud)

但是,当我尝试运行脚本时,我收到此错误: ImportError: No module named myapp.settings

更新2 刚看到我的错误......一切都很好

cet*_*eek 6

在Python中使用CSV支持.

方言分隔符更改为制表符.

链接页面有很多例子.