从 CSV 文件(逗号分隔)创建 postgres 外部表,该文件有一个电子邮件列,其中多个电子邮件地址用逗号分隔

Posted

技术标签:

【中文标题】从 CSV 文件(逗号分隔)创建 postgres 外部表,该文件有一个电子邮件列,其中多个电子邮件地址用逗号分隔【英文标题】:Creating a postgres External table from a CSV file (comma separated) which has an email column with multiple email addressed separated by comma 【发布时间】:2014-03-20 15:35:37 【问题描述】:

我正在尝试从 CSV 文件创建一个 postgres 外部表,该文件的一列作为电子邮件地址,并且该列有多个电子邮件地址,以逗号分隔。由于文件的分隔符是逗号,因此在创建外部表时,无法区分列内的“,”和列之间的“,”。电子邮件列中的电子邮件列表也用双引号括起来。 有没有办法在不改变整个文件的分隔符的情况下加载它?

【问题讨论】:

到目前为止你尝试了什么?你运行的是哪个版本的 PostgreSQL? ..您使用哪种编程语言,或者您想使用哪种编程语言来创建 SQL 插入命令? 【参考方案1】:

CSV 的标准做法是用双引号将字段括起来。COPY... CSV 将直接导入。

例子:

CREATE TABLE email(id int, emails text);
COPY email FROM STDIN CSV;
输入要复制的数据,后跟换行符。 以反斜杠和单独一行的句点结束。 >> 1,"abc@example.com,def@example.com" >> \。

结果:

从电子邮件中选择 * ; 编号 |电子邮件 --+------------------------------------ 1 | abc@example.com,def@example.com (1 行)

【讨论】:

以上是关于从 CSV 文件(逗号分隔)创建 postgres 外部表,该文件有一个电子邮件列,其中多个电子邮件地址用逗号分隔的主要内容,如果未能解决你的问题,请参考以下文章

Python STL csv

python 从KeepassX转换导出的XML文件,可以将其导入1Password(通过CSV逗号分隔文件)

使用逗号分隔符将单个 CSV 列批量转换为多个

用逗号分隔 HashMap 输出到 .csv

你如何用 awk 解析逗号分隔值(csv)?

CSV (逗号分隔值文件格式)