在日常开发和数据分析中,经常需要对表格数据进行转置,即将表格的行转化为列,将列转化为行。对于小型的表格,手动进行转置还较为简单,但是当数据规模变大之后,手动转置就极为繁琐、低效甚至出现错误。此时,就需要借助工具来完成转置任务。本文将介绍Linux系统中进行行列转置的相关技巧。
创新互联公司成立以来不断整合自身及行业资源、不断突破观念以使企业策略得到完善和成熟,建立了一套“以技术为基点,以客户需求中心、市场为导向”的快速反应体系。对公司的主营项目,如中高端企业网站企划 / 设计、行业 / 企业门户设计推广、行业门户平台运营、重庆App定制开发、手机网站开发、微信网站制作、软件开发、服务器托管德阳等实行标准化操作,让客户可以直观的预知到从创新互联公司可以获得的服务效果。
1. 实现转置的命令——transpose
在Linux系统中有一款专门用来实现行列转置的命令——transpose。该命令的实现过程非常简单:之一步将文本文件以行为单位读入内存,第二步将所有行拆分为单个数据项,第三步将单个数据项以列为单位写入输出文件。该命令的使用非常简单,以下是基本的用法示例:
将文件file.csv中的行转换为列输出:
“`
transpose file.csv
“`
将文件file.csv中的列转换为行输出:
“`
cat file.csv | transpose
“`
2. 使用cut和paste命令实现转置
除了使用专门的转置命令之外,还可以通过cut和paste两个命令进行转置。cut命令可以用来删除文本中的某些列,而paste命令可以用来将多个文本文件合并为一个文件。那么,通过cut和paste的组合使用,就可以实现文本文件的转置。
以下是具体的实现步骤:
(1)通过cut命令将原始文本文件file.csv中的列拆分成多个文件,每个文件只包括一列数据。以4列数据为例:
“`
cut -d’,’ -f1 file.csv > col1.txt
cut -d’,’ -f2 file.csv > col2.txt
cut -d’,’ -f3 file.csv > col3.txt
cut -d’,’ -f4 file.csv > col4.txt
“`
(2)通过paste命令将拆分后的多个文件按行合并为一个文件,即实现转置操作:
“`
paste col1.txt col2.txt col3.txt col4.txt > file_transposed.csv
“`
使用cut和paste命令进行转置的好处是可以自由选择需要转置的列,从而实现一个灵活的转置过程。
3. awk命令进行转置
awk命令是Linux系统中常用的文本处理工具之一,可以用于批量处理文本文件。同时,它也可以用于实现文本文件的行列转置。
以下是通过awk命令实现转置的步骤:
(1)读取原始文件,将行拆分为多个字段(以逗号作为分隔符):
“`
awk -F’,’ ‘{for(i=1;i file_transposed.csv
“`
该命令将原始文件按字段拆分,然后按列的方式输出。其中,-F参数指定了分隔符为逗号,a[i,NR]=$i将第i字段第NR行的数据存储在数组a中。
通过以上讨论,我们可以看出在Linux系统中,行列转置的操作可以通过方便而又灵活的命令来实现。transpose命令是一款专门用来进行转置的命令,使用简单,但是功能和灵活性有一定限制;cut和paste命令可以自由选择需要转置的列,灵活性较高;awk命令则是一款强大的文本处理工具,可以实现复杂的文本处理任务。
相关问题拓展阅读:
在日常工作中我们一般不是先把表格设计好后再填数据,而往往是先设计一个粗劣的表格填写数据后再慢慢修饰完善,所以会经常出现这样一种情况,行表头很长,列表头很短,看起来似乎像一个头重脚轻的表格,非常的不美观,而且浏览起来也很不方便,那么我们如何快速将这样的表格行列颠倒转置,使横向变为竖向,竖向变为横向呢?下面教大家两种方法。
一、选择性粘贴法
通过一个简单的复制粘贴就可以实现表格行列倒置,是不是超级简单呢。操作步骤如下:
1、单击选中原表格,然后按住鼠标左键不放选中整个表格,记住一定要按住鼠标左键不放,然后看左上角名称框里面显示所选表格是几行几列,9R×13C:R是指英文单词Row,表示行,C是指英文单词Column,表示列,所以9R×13C表示的是所选表格是9行13列。
2、单击鼠标右键选择复制,或者直接按复制快捷键Ctrl+C将选中的表格进行复制。
3、单击鼠标左键在空白单元格选择13行9列,因为需要行列倒置,所以需要跟原表格9行13列选择行列倒置的区域,同样可以看界面左上角的名称框显示方便选择空白区域。
4、单击鼠标右键选择选择性粘贴—粘贴内容转置,即可将表格行列进行转置。
但是运用这种方法有一个缺点就是当原表格数据变化时,行列转置后的表格不能跟随着同步变化,如果需要实现原表格数据变化,转换后的表格也同步变化,则需要运用到下一种方法公式法。
二、公式法
公式法之一步方法和选择性粘贴方法之一步操作基本一致,同样是单击鼠标左键选中整个表格然后看左上角名称框里面显示所选表格是几行几列。
公式法第二步和选择性粘贴方法第三步操作基本一致,单击鼠标左键在空白单元格选择与原表格列倒置的区域。
公式法第三步在选中的空白单元格直接输入函数公式=TRANSPOSE(原表格区域),然后在函数括号内单击选中整个原表格,最后按Ctrl+shift+enter组合键即可。
公式法第四步为转置后的表格添加边框,调整字体大小和水平居中即可。
综上所述两种方法其实都可以,之一种方法相对来说比较快捷一些,但是原表格数据变动行列倒置后的表格不能同步变动,而第二种方法需要输入函数,而且转置后表格格式发生转变需要进一步调整,相对来说比较麻烦,但却可以跟随原表格数据同步变化,所以采用哪种方法可以根据工作需要进行选择。
你还有其他好方法吗?欢迎评论区留言,喜欢记得点赞,转发+关注。
Linux下提供了iconv实现这袭渣一乱旦功能,在Linux 的 shell 环境下,iconv用法如下:
iconv -f fromconde -t tocode
-f: 指定需要转换的文本编码
-t: 指定目标文本编码
我们也可以用 -l 列举出所有哗禅扰已知的字符编码
iconv -l
具体用法可以通过帮助函数 iconv –help来详细了解
另外,我们也可以在程序中直接使用该函数实现文本的编码转换
#ifndef __CODE_CONVERTER
#define __CODE_CONVERTER
#ifdef WIN32
#include
#else
#include
#endif
class CodeConverter
{
private:
#ifndef WIN32
iconv_t m_cd;
#endif
const char* m_pszFromCode;
const char* m_pszToCode;
public:
CodeConverter()
{
m_pszFromCode = NULL;
m_pszToCode = NULL;
#ifndef WIN32
m_cd = 0;
#endif
}
~CodeConverter()
{
#ifndef WIN32
iconv_close(m_cd);
#endif
}
bool Initialize(const char *pszToCode, const char *pszFromCode);
size_t Convert(char* inBuf, size_t inBytesLeft, char* outBuf, size_t outBytesLen);
};
#endif
#include
#include
#include
#include “code_converter.h”
#include
bool CodeConverter::Initialize(const char* pszToCode, const char* pszFromCode)
{
if(pszFromCode == NULL || pszToCode == NULL) return false;
m_pszFromCode = pszFromCode;
m_pszToCode = pszToCode;
#ifndef WIN32
m_cd = iconv_open(m_pszToCode,m_pszFromCode);
if(m_cd == (iconv_t)-1)
{
printf(“cannot open iconv descripter\n”);
return false;
}
#endif
return true;
}
size_t CodeConverter:: Convert(char* inBuf, size_t inBytesLeft, char* outBuf, size_t outBytesLen)
{
int nRealLen = 0;
#ifdef WIN32
if(stricmp(m_pszFromCode,”UNICODE”) == 0)
{
nRealLen = WideCharToMultiByte(CP_ACP,0,(PWCHAR)inBuf, inBytesLeft, (PCHAR)outBuf, outBytesLen,NULL,NULL);
}
if(stricmp(m_pszFromCode,”gb2312″) == 0)
{
nRealLen = MultiByteToWideChar(CP_ACP,0,(PCHAR)inBuf,inBytesLeft,(PWCHAR)outBuf, outBytesLen);
}
#else
size_t outBytesLeft = outBytesLen;
size_t ret = 0;
while (1)
{
ret = iconv(m_cd, &inBuf, &inBytesLeft, &outBuf, &outBytesLeft);
if (ret == 0) break;
if (ret == (size_t)-1)
{
printf(“iconv error aaa: %s\n”,strerror(errno));
return -1;
}
inBuf++; inBytesLeft–;
}
nRealLen = outBytesLen-outBytesLeft;
outBuf=0;
#endif
return nRealLen;
linux行列转置的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux行列转置,优雅解决:Linux行列转置技巧简析,excel怎样快速把表格行列倒置,使横向变为竖向,如何在Linux系统实现字符编码转换的信息别忘了在本站进行查找喔。
香港服务器选创新互联,2H2G首月10元开通。
创新互联(www.cdcxhl.com)互联网服务提供商,拥有超过10年的服务器租用、服务器托管、云服务器、虚拟主机、网站系统开发经验。专业提供云主机、虚拟主机、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。
网站题目:优雅解决:Linux行列转置技巧简析(linux行列转置)
转载来于:http://www.csdahua.cn/qtweb/news46/149146.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网