psql 到 csv 文件 '-' 变为 '-0'
Posted
技术标签:
【中文标题】psql 到 csv 文件 \'-\' 变为 \'-0\'【英文标题】:psql to csv file '-' becomes '-0'psql 到 csv 文件 '-' 变为 '-0' 【发布时间】:2013-11-20 14:05:39 【问题描述】:我想将 psql 查询的结果输出到 csv 文件。我使用了以下方法
\o test.csv
SELECT myo_date, myo_maps_study, cbp_lvef, cbp_rvef, myx_ecg_posneg, myx_st, std_drugs, std_reason_comment FROM myo INNER JOIN studies ON (myo_std_uid = std_uid) LEFT OUTER JOIN cbp on (std_uid = cbp_std_uid) LEFT OUTER JOIN myx on (std_uid = myx_std_uid) WHERE myo_maps_study ~ 'MYO[0-9]*\$' AND std_reason_comment ~ 'AF' AND cbp_lvef is not null AND myx_st IS NOT NULL AND std_drugs IS NOT NULL ORDER by myo_date DESC LIMIT 500;
\q
自行查询的结果如下
06/11/2013 | MYO134537 | 36.75000 | 29.00000 | - | 0.0 | ASPIRIN;BISOPROLOL;LISINOPRIL;METFORMIN;PPI;STATIN;FLUOXETINE;AMLODIPINE;GTN | CPOE;AF;T2DM;POSET
31/10/2013 | MYO130555 | 45.00000 | 36.25000 | - | 0.0 | DILTIAZEM;STATIN;LISINOPRIL;ASPIRIN;FRUSEMIDE;SALBUTAMOL;PARACETAMOL;AMOXICILLIN | TROP-VE; CP; AF; CTPA-VE; ANT T; INV; RF
23/10/2013 | MYO130538 | 18.75000 | 18.50000 | + | -1.0 | ASPIRIN;BISOPROLOL;RAMIPRIL | AF;MR;QLVFN;FAILED CARDIOVERSION
18/10/2013 | MYO134510 | 39.50000 | 32.25000 | - | 0.0 | ASPIRIN;STATIN;CO-CODAMOL;BISOPROLOL;GTN;PPI | PVD;AF
18/10/2013 | MYO130537 | 19.00000 | 18.00000 | - | 0.0 | STATIN;RAMIPRIL;AMLODIPINE;WARFARIN;(METOPROLOL-STOPPED FOR TEST) | TIA;AF;RF+++;ETINAP
但是 csv 文件(在开放式办公室中打开)看起来像这样
06/11/2013 MYO134537 36.75 29 -0 0 ASPIRIN;BISOPROLOL;LISINOPRIL;METFORMIN;PPI;STATIN;FLUOXETINE;AMLODIPINE;GTN CPOE;AF;T2DM;POSET
31/10/2013 MYO130555 45 36.25 -0 0 DILTIAZEM;STATIN;LISINOPRIL;ASPIRIN;FRUSEMIDE;SALBUTAMOL;PARACETAMOL;AMOXICILLIN TROP-VE; CP; AF; CTPA-VE; ANT T; INV; RF
23/10/2013 MYO130538 18.75 18.5 0 -1 ASPIRIN;BISOPROLOL;RAMIPRIL AF;MR;QLVFN;FAILED CARDIOVERSION
18/10/2013 MYO134510 39.5 32.25 -0 0 ASPIRIN;STATIN;CO-CODAMOL;BISOPROLOL;GTN;PPI PVD;AF
18/10/2013 MYO130537 19 18 -0 0 STATIN;RAMIPRIL;AMLODIPINE;WARFARIN;(METOPROLOL-STOPPED FOR TEST) TIA;AF;RF+++;ETINAP
'-' 符号变成了 -0 和 '+' 变成了 0。为了清楚起见,我想将它们分别更改为 N 和 P。
做一个more test.csv
给了
06/11/2013,MYO134537,36.75,29,-0,0,ASPIRIN;BISOPROLOL;LISINOPRIL;METFORMIN;PPI;STATIN;FLUOXETINE;AMLODIPINE;GTN,CPOE;AF;T2DM;POSET,,
31/10/2013,MYO130555,45,36.25,-0,0,DILTIAZEM;STATIN;LISINOPRIL;ASPIRIN;FRUSEMIDE;SALBUTAMOL;PARACETAMOL;AMOXICILLIN,TROP-VE; CP; AF; CTPA-VE; ANT T; INV; RF,,
23/10/2013,MYO130538,18.75,18.5,0,-1,ASPIRIN;BISOPROLOL;RAMIPRIL,AF;MR;QLVFN;FAILED CARDIOVERSION,,
18/10/2013,MYO134510,39.5,32.25,-0,0,ASPIRIN;STATIN;CO-CODAMOL;BISOPROLOL;GTN;PPI,PVD;AF,,
18/10/2013,MYO130537,19,18,-0,0,STATIN;RAMIPRIL;AMLODIPINE;WARFARIN;(METOPROLOL-STOPPED FOR TEST),TIA;AF;RF+++;ETINAP,,
但是,当我在开放式办公室中选择单元格时,-0 或 0 单元格的内容始终为 0。这不允许我进行搜索替换。我不想手动更改这些。
我可以通过使用 psql 命令强制 + 和 - 吗,或者我可以使用其他一些 linux 工具将 -0 更改为 N 并将 0 更改为 P。我使用的是 RHEL6。
【问题讨论】:
您说您的字段在 Open Office 中变为零,但这仅表示您错误地导入了字段。您是否尝试将字段从数字更改为字符串? @TLP 你是正确的,因为我在文本导入预览屏幕中看到 + 和 -。但是,将字段从数字更改为字符串(文本)没有影响 听起来好像在那个阶段已经把-
改成了-0
,所以你需要想办法正确导入。
【参考方案1】:
尝试使用decode function 代替字段名称。
decode(myx_ecg_posneg,'-','N','+','P')
更新:抱歉,这是 pl/sql。试试 case 表达式:
CASE myx_ecg_posneg
WHEN '-' THEN 'N'
WHEN '+' THEN 'P'
END
【讨论】:
字段 myx_ecg_posneg 是字符类型,我收到以下错误ERROR: function decode(character, "unknown", "unknown") does not exist HINT: No function matches the given name and argument types. You may need to add explicit type casts.
以上是关于psql 到 csv 文件 '-' 变为 '-0'的主要内容,如果未能解决你的问题,请参考以下文章
在 java 上将 csv 文件加载到 GreenPlum 失败