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'的主要内容,如果未能解决你的问题,请参考以下文章

从标准输入复制 CSV 文件会引发“列缺失数据”

psql备份csv文件

在 java 上将 csv 文件加载到 GreenPlum 失败

如何使用psql导出Redshift集群的CSV格式的数据

关于excel保存为csv格式后,重新打开文本型数字变为科学计数,且15位后面变成0??

PSQL /copy : 变量替换不起作用 | PostgreSQL 11