精华内容
下载资源
问答
  • 多行内容合并一行的两种方式

    千次阅读 2021-01-14 10:07:03
    在利用Unix操作系统在实现一些具体...但是在报表显示的时候,可能希望对于同一张材料上的号码,能够在同一行上显示,不同的行码之间利用分隔符进行分割。此时就需要用到Unix操作系统中的合并行的实现方式。如下图所...

    在利用Unix操作系统在实现一些具体应用的时候,可能需要把某些显示的结果进行行与行之间的合并。如现在需要用Unix操作系统设计一个彩票软件,每一张彩票上最多可以打印五注内容。在Unix操作系统的数据文件中这五注内容是按五行来存放的。但是在报表显示的时候,可能希望对于同一张材料上的号码,能够在同一行上显示,不同的行码之间利用分隔符进行分割。此时就需要用到Unix操作系统中的合并行的实现方式。如下图所示:

    如上图中,左边是原始文件,右边是需要的文件格式。那该如何实现呢?在Unix操作系统中,主要有两种方式可以实现这个需求。可能还有其他笔者不了解的实现方式。

    第一种方式:利用vi命令中的J选项。

    在一些文本处理软件中,要把某一行与下一行之间进行合并,这是很简单的一个操作。至需要把行与行之间的行分隔符删除即可。但是对于Unix操作系统中的vi命令这个做法没有效果。而且每天要卖出几百张彩票,每张彩票的号码都需要这么处理的话,那么用户还不把你骂死。为此系统工程师必须要想一些两全其美的方法,即可以实现行与行合并的需求,又不会增加很多的工作量。

    此时如果能够灵活应用Unix操作系统中的vi命令中的J选项就可以实现这个需求。J选项主要用来删除行与行之间的换行符,并把下一行的内容添加到当前行的后面。不过在使用这个选项的时候,需要注意行的总长度是有限制的。在Unix操作系统中,一行的内容不能够超过vi允许的最大行长度,一般情况下为2000。不过在Linux操作系统中,则没有这方面的限制。从这个需求来看,一张彩票最多只能够打印五注号码,每注号码为7个字符,再彩票的序列号为8个字符,那么一行最多也就是50个字符(再加上四个分隔符)。

    为此可以在校本程序中利用While 循环,把同一个彩票序号下的行进行合并(利用vi命令的J选项删除行分隔符),然后再在每个彩票号码后面加入|分隔符即可。不过vi命名与While循环语句结合时比较难以控制。笔者在实现类似需求的时候,不怎么利用这个vi命令,而是采用后面这种处理方式。

    第二种处理方式:利用paste命令来实现。

    Paste命令顾名思义就是一个粘贴命令。但是这个paste命令有比较多复杂的选项,利用这些选项可以实现一些比较复杂的需求。如果要实现以上的需求的话,那么主要需要使用的是paste命令中的-s与-d两个选项。

    -d选项主要用来指定需要采用的分隔符。如需要把原先分布在不同行之内的彩票号码合并在同一行时,需要使用什么符号来进行分隔。为了提高合并后文件的可读性,行合并后的内容肯定需要采用分隔符进行分隔。Paste命令所采用的默认选项为空格符。也就是说如果不特殊指定的话,彩票号码之间是使用空格来进行分隔的。就如同“4522467 4672435”一般显示。但是这仍然不怎么直观。如果我们需要使用其他符号,如|符号来进行分隔的话,则需要利用-d选项来指定这个分隔符。

    -s选项主要用来合并行。也就是说,使用paste命令的-s可选项可以实现像vi命令的J选项那样的功能,可以把多行的内容合并在一起。但是光用这个选项的话,还不能够实现如上的需求。如利用paste ?s num.txt命令,则操作系统是会把分布在各行中的内容合并起来,但是其是合并为一行。也就是说,如果一个文件中有300行的内容,那么其会把这些行的内容合并在一行,中间利用分隔符来进行分隔。这合并后的结果可读性会比较差,不是我们所希望看到的结果。

    此时我们就需要把这连个选项来结合使用。要实现文章刚开始那样的需求,可以通过命令“paste ?s ?d “|||||\n” 文件名”来实现。采用这个命令后,操作系统会以循环的方式插入分隔符。如上面这个文件,其可以把第一行与第二行合并成一行,中间利用|分隔符进行分割;然后把第二行与第三行进行合并,中间也利用|分隔符进行合并。以此类推,直到把第五行与第六行进行合并,并利用|分隔符进行分隔。当第六行与第七行的时候,也是会先合并,但是其中会以一个分行符号进行分隔。此时其实就是另起一行的意思了。操作系统会按照这个运作方式,直到文件结束为止。最后这个文件的显示结果如下:

    最后显示的结果与用户最终需要的结果可能稍微有点差别。如用户需要利用|分隔符来进行分隔。这个也是可以实现的,只需要把命令中的#符号换成|符合即可。但是笔者还是建议用户采用#分隔符为好。因为|这个分隔符号根数字1很相像,很容易引起误读。所以笔者这里采用了#这个不容易误读的分隔符。另外利用paste命令来进行合并行的时候,只能够按固定的行数来分隔。如上面笔者连续使用了五个#分隔符和一个分行符号,就表示是连续把六行的内容合并在一起,然后插入一个分行符号。但是在买彩票的时候,可能一张彩票上只有三个号码。此时就需要在原始文件中插入一行空行。也就是说在彩票号码保存的时候,一张彩票必须要有六行的内容。如果刚好一张彩票买了五柱那是最好。如果不到五个号码的话,那么在文件保存的时候最好能够让程序补足剩余的行数。只有如此才能够利用paste命令来按一定的规律来合并行数。如上图所示,后面连续###就是因为文件中的空行所致。可见利用“paste ?s ?d “|||||\n” 文件名”这种方式来实现文件中行的合并要比使用vi命令简单的多。如果用户需要把这个结果保存在文件中的话,就可以利用重定向符号把其保存起来,以便后续查询或者打印操作等等。

    Paste命令是Unix操作系统中功能很强的一个命令,特别是跟其他命令结合更能够实现一些非常复杂的功能。这也是Unix操作系统命令操作方式令人向往的地方。如可以把这个命令跟CUT命令结合。用CUT命令街区的内容可以通过paste命令粘贴到另一个位置,从而实现垂直方式的粘贴等等。这个功能在微软的Word文本中是无法实现的,只有在其Excel表格中才能够实现。而Unix操作系统中即使对于普通的文本文件,也可以实现类似Excel的表格操作。

    可见,paste命令可以把两个以上的文件按一定的规则合并起来。如现在有两个记事本文件,一个文件存储着学生的学号、姓名;另一个文件存储着学生的学号、总成绩、年级排名等等。两个文件是学号是一一对应的,并且按照一定的顺序排列。现在需要把两个文件进行合并,变为包含学号、姓名、总成绩、年级排序的内容。也就是说要把第一个文件中的学生名字加入到第二个文件中。如果在微软操作系统下,在其记事本工具中是无法实现这个何合并的。而是需要先利用EXCLE表格工具把这两个文件打开,然后再把学生名字复制到另外一张表格中去。如果没有Excle等表格处理工具,那么就无法实现这个需求。但是在Unix操作系统中,则只需要凭借简单地cut命令与paste命令结合就可以把学生姓名内容复制到另外一个文件中。所以说,paste命令与find命令一样,是一个令人称奇的命令。另外值得一提的就是,paste命令不仅可以用来实现文件与文件的合并,还可以把终端输出的内容与存在的物理文件尽心合并。这里由于篇幅限制对这方面的内容就不做过多展开了。以后如果有机会的话,笔者会对会详细介绍如何利用paste命令来实现标准输入与物理文件的结合。若有这方面的需要请请大家关注笔者后续的文章。

    展开全文
  • mysql中将多行数据合并一行数据

    千次阅读 2021-01-19 04:35:11
    一个字段可能对应多条数据,用mysql实现将多行数据合并一行数据例如:一个活动id(activeId)对应多个模块名(modelName),按照一般的sql语句:1 SELECT am.activeId,m.modelName2 FROM activemodel am3 JOIN model m4...

    一个字段可能对应多条数据,用mysql实现将多行数据合并成一行数据

    例如:一个活动id(activeId)对应多个模块名(modelName),按照一般的sql语句:

    1 SELECT am.activeId,m.modelName

    2 FROM activemodel am

    3 JOIN model m

    4 ON am.modelId = m.modelId

    5 ORDER BY am.activeId

    查询出的列表为图1所示:

    d14213bbee2b2c59e50d55aba83af512.png

    修改过后的sql语句,查询后如图2所示:

    1 SELECT am.activeId,GROUP_CONCAT(m.modelName SEPARATOR ',') modelName

    2 FROM activemodel am

    3 JOIN model m

    4 ON am.modelId=m.modelId

    5 WHERE m.valid=1

    6 GROUP BY am.activeId

    需注意:

    1.GROUP_CONCAT()中的值为你要合并的数据的字段名;

    SEPARATOR 函数是用来分隔这些要合并的数据的;

    ' '中是你要用哪个符号来分隔;

    2.必须要用GROUP BY 语句来进行分组管理,不然所有的数据都会被合并成一条记录,

    dc8d0ccf86407cdc7f52928cb02da9cf.png

    如图3

    394cdff01bdd39843f2dd641e38ab3db.png

    SELECT order_id ,GROUP_CONCAT( (case when azfxj >0 and type = '0' then CONCAT('就(', area_2,'m²' , ' ', count_2,'套)') else '' end ) SEPARATOR ',') modelNameFROMtypg_house_order_choosewhere order_id='0500c6a25f2249c08289970305eacc11'

    GROUP BY order_id

    展开全文
  • MySQL多选数据合并成为一行--GROUP_CONCAT()当数据中出现一对多,且需要把多的数据转换为一,形成一对一的数据形式。此时,可以通过程序实现,也可以通过sql直接实现。此处采取SQL方式进行数据处理。SQL方法:利用...

    MySQL多选数据合并成为一行--GROUP_CONCAT()

    当数据中出现一对多,且需要把多的数据转换为一,形成一对一的数据形式。

    此时,可以通过程序实现,也可以通过sql直接实现。此处采取SQL方式进行数据处理。

    SQL方法:

    利用GROUP_CONCAT ()方法,参数为需要合并的字段,合并的字段分隔符默认为逗号,可通过参数separator指定。此方法一般与 GROUP BY配合使用。

    例子如下 :

    1、 测试数据

    Sql:

    select a.goods_name as '商品名', a.supply_name '供应商' from tb_goods_info as a;

    6dbd8669c94e8fe5ce8f611d249c4b60.png

    2、 没有GROUP BY情况下,进行多端数据的合并。此时一般无法达到要求。

    Sql:

    select GROUP_CONCAT(a.goods_name) as '商品名', a.supply_name '供应商' from tb_goods_info as a;

    c0f1d7aae9ff8471ed7f7c28f2c642b9.png

    3、 与GROUP BY配合使用,使用默认分隔符。

    Sql:

    select GROUP_CONCAT(a.goods_name) as '商品名', a.supply_name '供应商'

    from tb_goods_info as a

    GROUP BY a.supply_name;

    292bfdedfeb920e5d5c79b6bfc27b37c.png

    4、 与GROUP BY配合使用,指定分隔符。

    Sql:

    select GROUP_CONCAT(a.goods_name SEPARATOR '--/--') as '商品名', a.supply_name '供应商'

    from tb_goods_info as a

    GROUP BY a.supply_name;

    e45b0fee0047dbad4480a8ba358d6ed5.png

    展开全文
  • 方案:wm_concat函数select username, id, wmsys.wm_concat(subject) as subject, wmsys.wm_concat(score) as scorefrom STUDENTSCORESgroup by username, id方案二:listagg函数select username, id, LISTAGG...

    方案一:wm_concat函数

    select username, id, wmsys.wm_concat(subject) as subject, wmsys.wm_concat(score) as score

    from STUDENTSCORES

    group by username, id

    方案二:listagg函数

    select username, id, LISTAGG(subject, ‘-‘) within group(order by subject) as subject, LISTAGG(score, ‘,‘) within group(order by score) as score

    from STUDENTSCORES

    group by username, id

    方案三:常规sql

    select username, id, translate(ltrim(subject, ‘/‘), ‘*/‘, ‘*,‘) as subject,translate(ltrim (score, ‘/‘), ‘*/‘, ‘*,‘) as score

    from

    (select row_number() over (partition by username, id order by username, id, lvl desc) as rn, username, id, subject, score

    from

    (select username, id, level lvl,                            sys_connect_by_path (subject, ‘/‘) as subject, sys_connect_by_path (score, ‘/‘) as score

    from

    (select username, id, subject, score,                                       row_number() over (partition by username,id order by username, id) as num from STUDENTSCORES order by username, id)

    connect by username = prior username and id = prior id and num - 1 = prior num))

    where rn = 1;

    注意:

    方案一中默认分隔符为 ‘,’

    方案二只适合11g之后的版本

    原文:https://www.cnblogs.com/qqjj/p/12922272.html

    展开全文
  • '用途,将同客户合同号同样的模具号 的不同颜色合并到一个字段里合并前的数据'客合同 款号 颜色 数量'A 9001 黑色 100'A 9001 白色 200'A 9001 红色 300'''不用ADO 或DAO ,用查询,大家有什么比较好的办法 显示为:'...
  • CONCAT(md.data1) FROM DATA md,contacts cc WHERE md.conskey=cc.id AND md.mimetype_id= 5 AND md.user_id=17:利用函数:group_concat(),实现一个ID对应多个名称时,原本为多行数据,把名称合并一行,...
  • 1.excel里如何把多行数据合并一行excel里把多行数据合并一行的具体步骤如下:1、首先打开需要编辑的Excel表格,进入编辑页面中。2、然后选中需要合并的数据,将单元格拉至合适的大小。3、然后点击填充后面的倒...
  • Postgresql多行数据合并一行显示

    千次阅读 2021-05-20 09:09:10
    Postgresql多行数据合并一行显示方式一:使用string_agg函数,直接把一个表达式变成字符串方式二:使用array_agg函数,,把表达式变成一个数组,一般配合 array_to_string() 函数使用 方式一:使用string_agg函数,直接...
  • 多行语句合并一行三个表关联查询的结果集为:SELECT users.name,users.age,users.birthday,roles.name FROM users,users_roles,roles WHERE users_roles.userid = users.id and users_roles.roleid = roles.idname ...
  • 多行合并一行

    2021-03-02 09:01:27
    ctrl + shift + j
  • LISTAGG(列名,'分割符号')oracle 11g 以上的版本才有的一个将指定列名的多行查询结果,用 指定的分割符号合并一行显示:例如:表原始数据: 需求:将 mb1_Transport_License_list 表中的数据,根据 transportation...
  • " 数据表的记录如下: 5112 960024 5112 960025 5112 960026 5112 960027 5112 960028 5113 960043 5113 960044 5113 960045 5113 960046 对promotion_id进行合并: select product_id, concat_ws('_',collect_set...
  • SELECT class, wm_concat(distinct ',', name) FROM students GROUP BY class; 参考
  • 本篇属于经验贴,适用的问题是:需要将excel的多列数据粘贴为一列或者一行 方法:本次解决方法需要下载一个好用的插件,叫做方方格子,强推这个插件,直接搜官网然后下载软件,安装后重启excel任务栏会出现方方格子...
  • 表数据 将group by 后重复的数据拼接起来 SELECT t.job, wmsys.wm_concat(t.ename) as naems, count(1) FROM emp t GROUP BY t.job;...将多行数据转为一行数据 select wm_concat(t.ename) names from emp t;
  • 原表格是这样 命令后是这样的 网上偷师学来的,但是不能指定日期区间和有很多空白,不知道怎么写了。
  • excel如何将多行数据合并一行

    千次阅读 2020-12-23 13:08:02
    这个用VB来得快一点,不过个人习惯性用公式,所以就先说一下公式的算法。...3、从表1的1、2、3行,转移表2的第一行,即需要跨表格引用。那么就可以写了:=OFFSET(Sheet1!$A$1,IF(MOD(COLUMN(),COUNT(Sheet...
  • pandas之多行按类合并一行

    千次阅读 2021-01-30 04:32:45
    前言前面讲explode操作是把某一列中的嵌套列表拆分为多行那有时候我们会有着相反的需求,即按照某一列,把相同值对应的多行合并一行原理主要用到groupby函数+apply函数读取数据data=pd.read_csv('data.csv',...
  • SQL SERVER将多行数据合并一行(转载) 昨天遇到一个SQL Server的问题:需要写一个储存过程来处理几个表中的数据,最后问题出在我想将一个表的一个列的多行内容拼接成一行 比如表中有两列数据 : ep_classes ep_name ...
  • 一个字段可能对应多条数据,用mysql实现将多行数据合并一行数据 例如:一个活动id(activeId)对应多个模块名(modelName),按照一般的sql语句: 1 SELECT am.activeId,m.modelName 2 FROM activemodel am 3 ...
  • 我们有时候需要进行特定的in查询,这个时候可能需要先把想要in的数据,拼接成条逗号分割的数据 类似这样 select * from admin where id in (1,2,3) 这个时候可以通过sql语句操作一下,取出拼接好的1,2,3 select ...
  • 如果是oracle 10g以上 个wm_concat函数就可以解决。——有时候会报错如果是oracle 9i以下就有点麻烦了。例如有如下数据:000297 chenpeng000297 liusu合并处理后需显示为:000297...
  • 必须要用GROUP BY 语句来进行分组管理,不然所有的数据都会被合并条记录,如图3 例:将查询结果用逗号分隔 select Group_concat(id) from tab; 注:用Group_concat进行合并的字段,如果是空字符串,假设分隔...
  • Oracle多行数据合并一行 一、listagg 函数------(有长度限制) SELECT listagg(待拼接字段, ',') within group(ORDER BY 待拼接字段) AS NAMES FROM 表 GROUP BY 字段 二、用聚合函数,然后使用 wmsys.wm_concat...
  • 1. 多行合并一行:使用函数collect_list 假如现在数据表table1如下所示: col1 col2 col3 A B 1 A B 2 A C 3 A C 4 我们想将col1和col2值相同的col3合并成一行,得到如下的数据表,使用函数collect_list Col1 col2...
  • ORACLE多行合并一行

    2021-05-06 08:32:00
    demo场景,以oracle自带库中的表emp为例:select ...ENAMEDEPTNOCLARK10KING10MILLER10SMITH20ADAMS20FORD20SCOTT20JONES20ALLEN30BLAKE30MARTIN30JAMES30TURNER30WARD30现在想要将同一部门的人给合并一行记录,...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 65,669
精华内容 26,267
关键字:

多行内容合并到一行

友情链接: ch372.rar