新聞中心
在日常開發(fā)和數(shù)據(jù)分析中,經(jīng)常需要對表格數(shù)據(jù)進(jìn)行轉(zhuǎn)置,即將表格的行轉(zhuǎn)化為列,將列轉(zhuǎn)化為行。對于小型的表格,手動進(jìn)行轉(zhuǎn)置還較為簡單,但是當(dāng)數(shù)據(jù)規(guī)模變大之后,手動轉(zhuǎn)置就極為繁瑣、低效甚至出現(xiàn)錯誤。此時(shí),就需要借助工具來完成轉(zhuǎn)置任務(wù)。本文將介紹Linux系統(tǒng)中進(jìn)行行列轉(zhuǎn)置的相關(guān)技巧。

創(chuàng)新互聯(lián)公司成立以來不斷整合自身及行業(yè)資源、不斷突破觀念以使企業(yè)策略得到完善和成熟,建立了一套“以技術(shù)為基點(diǎn),以客戶需求中心、市場為導(dǎo)向”的快速反應(yīng)體系。對公司的主營項(xiàng)目,如中高端企業(yè)網(wǎng)站企劃 / 設(shè)計(jì)、行業(yè) / 企業(yè)門戶設(shè)計(jì)推廣、行業(yè)門戶平臺運(yùn)營、重慶App定制開發(fā)、手機(jī)網(wǎng)站開發(fā)、微信網(wǎng)站制作、軟件開發(fā)、服務(wù)器托管德陽等實(shí)行標(biāo)準(zhǔn)化操作,讓客戶可以直觀的預(yù)知到從創(chuàng)新互聯(lián)公司可以獲得的服務(wù)效果。
1. 實(shí)現(xiàn)轉(zhuǎn)置的命令——transpose
在Linux系統(tǒng)中有一款專門用來實(shí)現(xiàn)行列轉(zhuǎn)置的命令——transpose。該命令的實(shí)現(xiàn)過程非常簡單:之一步將文本文件以行為單位讀入內(nèi)存,第二步將所有行拆分為單個(gè)數(shù)據(jù)項(xiàng),第三步將單個(gè)數(shù)據(jù)項(xiàng)以列為單位寫入輸出文件。該命令的使用非常簡單,以下是基本的用法示例:
將文件file.csv中的行轉(zhuǎn)換為列輸出:
“`
transpose file.csv
“`
將文件file.csv中的列轉(zhuǎn)換為行輸出:
“`
cat file.csv | transpose
“`
2. 使用cut和paste命令實(shí)現(xiàn)轉(zhuǎn)置
除了使用專門的轉(zhuǎn)置命令之外,還可以通過cut和paste兩個(gè)命令進(jìn)行轉(zhuǎn)置。cut命令可以用來刪除文本中的某些列,而paste命令可以用來將多個(gè)文本文件合并為一個(gè)文件。那么,通過cut和paste的組合使用,就可以實(shí)現(xiàn)文本文件的轉(zhuǎn)置。
以下是具體的實(shí)現(xiàn)步驟:
(1)通過cut命令將原始文本文件file.csv中的列拆分成多個(gè)文件,每個(gè)文件只包括一列數(shù)據(jù)。以4列數(shù)據(jù)為例:
“`
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命令將拆分后的多個(gè)文件按行合并為一個(gè)文件,即實(shí)現(xiàn)轉(zhuǎn)置操作:
“`
paste col1.txt col2.txt col3.txt col4.txt > file_transposed.csv
“`
使用cut和paste命令進(jìn)行轉(zhuǎn)置的好處是可以自由選擇需要轉(zhuǎn)置的列,從而實(shí)現(xiàn)一個(gè)靈活的轉(zhuǎn)置過程。
3. awk命令進(jìn)行轉(zhuǎn)置
awk命令是Linux系統(tǒng)中常用的文本處理工具之一,可以用于批量處理文本文件。同時(shí),它也可以用于實(shí)現(xiàn)文本文件的行列轉(zhuǎn)置。
以下是通過awk命令實(shí)現(xiàn)轉(zhuǎn)置的步驟:
(1)讀取原始文件,將行拆分為多個(gè)字段(以逗號作為分隔符):
“`
awk -F’,’ ‘{for(i=1;i file_transposed.csv
“`
該命令將原始文件按字段拆分,然后按列的方式輸出。其中,-F參數(shù)指定了分隔符為逗號,a[i,NR]=$i將第i字段第NR行的數(shù)據(jù)存儲在數(shù)組a中。
通過以上討論,我們可以看出在Linux系統(tǒng)中,行列轉(zhuǎn)置的操作可以通過方便而又靈活的命令來實(shí)現(xiàn)。transpose命令是一款專門用來進(jìn)行轉(zhuǎn)置的命令,使用簡單,但是功能和靈活性有一定限制;cut和paste命令可以自由選擇需要轉(zhuǎn)置的列,靈活性較高;awk命令則是一款強(qiáng)大的文本處理工具,可以實(shí)現(xiàn)復(fù)雜的文本處理任務(wù)。
相關(guān)問題拓展閱讀:
- excel怎樣快速把表格行列倒置,使橫向變?yōu)樨Q向
- 如何在Linux系統(tǒng)實(shí)現(xiàn)字符編碼轉(zhuǎn)換
excel怎樣快速把表格行列倒置,使橫向變?yōu)樨Q向
在日常工作中我們一般不是先把表格設(shè)計(jì)好后再填數(shù)據(jù),而往往是先設(shè)計(jì)一個(gè)粗劣的表格填寫數(shù)據(jù)后再慢慢修飾完善,所以會經(jīng)常出現(xiàn)這樣一種情況,行表頭很長,列表頭很短,看起來似乎像一個(gè)頭重腳輕的表格,非常的不美觀,而且瀏覽起來也很不方便,那么我們?nèi)绾慰焖賹⑦@樣的表格行列顛倒轉(zhuǎn)置,使橫向變?yōu)樨Q向,豎向變?yōu)闄M向呢?下面教大家兩種方法。
一、選擇性粘貼法
通過一個(gè)簡單的復(fù)制粘貼就可以實(shí)現(xiàn)表格行列倒置,是不是超級簡單呢。操作步驟如下:
1、單擊選中原表格,然后按住鼠標(biāo)左鍵不放選中整個(gè)表格,記住一定要按住鼠標(biāo)左鍵不放,然后看左上角名稱框里面顯示所選表格是幾行幾列,9R×13C:R是指英文單詞Row,表示行,C是指英文單詞Column,表示列,所以9R×13C表示的是所選表格是9行13列。
2、單擊鼠標(biāo)右鍵選擇復(fù)制,或者直接按復(fù)制快捷鍵Ctrl+C將選中的表格進(jìn)行復(fù)制。
3、單擊鼠標(biāo)左鍵在空白單元格選擇13行9列,因?yàn)樾枰辛械怪茫孕枰砀?行13列選擇行列倒置的區(qū)域,同樣可以看界面左上角的名稱框顯示方便選擇空白區(qū)域。
4、單擊鼠標(biāo)右鍵選擇選擇性粘貼—粘貼內(nèi)容轉(zhuǎn)置,即可將表格行列進(jìn)行轉(zhuǎn)置。
但是運(yùn)用這種方法有一個(gè)缺點(diǎn)就是當(dāng)原表格數(shù)據(jù)變化時(shí),行列轉(zhuǎn)置后的表格不能跟隨著同步變化,如果需要實(shí)現(xiàn)原表格數(shù)據(jù)變化,轉(zhuǎn)換后的表格也同步變化,則需要運(yùn)用到下一種方法公式法。
二、公式法
公式法之一步方法和選擇性粘貼方法之一步操作基本一致,同樣是單擊鼠標(biāo)左鍵選中整個(gè)表格然后看左上角名稱框里面顯示所選表格是幾行幾列。
公式法第二步和選擇性粘貼方法第三步操作基本一致,單擊鼠標(biāo)左鍵在空白單元格選擇與原表格列倒置的區(qū)域。
公式法第三步在選中的空白單元格直接輸入函數(shù)公式=TRANSPOSE(原表格區(qū)域),然后在函數(shù)括號內(nèi)單擊選中整個(gè)原表格,最后按Ctrl+shift+enter組合鍵即可。
公式法第四步為轉(zhuǎn)置后的表格添加邊框,調(diào)整字體大小和水平居中即可。
綜上所述兩種方法其實(shí)都可以,之一種方法相對來說比較快捷一些,但是原表格數(shù)據(jù)變動行列倒置后的表格不能同步變動,而第二種方法需要輸入函數(shù),而且轉(zhuǎn)置后表格格式發(fā)生轉(zhuǎn)變需要進(jìn)一步調(diào)整,相對來說比較麻煩,但卻可以跟隨原表格數(shù)據(jù)同步變化,所以采用哪種方法可以根據(jù)工作需要進(jìn)行選擇。
你還有其他好方法嗎?歡迎評論區(qū)留言,喜歡記得點(diǎn)贊,轉(zhuǎn)發(fā)+關(guān)注。
如何在Linux系統(tǒng)實(shí)現(xiàn)字符編碼轉(zhuǎn)換
Linux下提供了iconv實(shí)現(xiàn)這襲渣一亂旦功能,在Linux 的 shell 環(huán)境下,iconv用法如下:
iconv -f fromconde -t tocode
-f: 指定需要轉(zhuǎn)換的文本編碼
-t: 指定目標(biāo)文本編碼
我們也可以用 -l 列舉出所有嘩禪擾已知的字符編碼
iconv -l
具體用法可以通過幫助函數(shù) iconv –help來詳細(xì)了解
另外,我們也可以在程序中直接使用該函數(shù)實(shí)現(xiàn)文本的編碼轉(zhuǎn)換
#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行列轉(zhuǎn)置的介紹就聊到這里吧,感謝你花時(shí)間閱讀本站內(nèi)容,更多關(guān)于linux行列轉(zhuǎn)置,優(yōu)雅解決:Linux行列轉(zhuǎn)置技巧簡析,excel怎樣快速把表格行列倒置,使橫向變?yōu)樨Q向,如何在Linux系統(tǒng)實(shí)現(xiàn)字符編碼轉(zhuǎn)換的信息別忘了在本站進(jìn)行查找喔。
香港服務(wù)器選創(chuàng)新互聯(lián),2H2G首月10元開通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務(wù)提供商,擁有超過10年的服務(wù)器租用、服務(wù)器托管、云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗(yàn)。專業(yè)提供云主機(jī)、虛擬主機(jī)、域名注冊、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。
分享文章:優(yōu)雅解決:Linux行列轉(zhuǎn)置技巧簡析(linux行列轉(zhuǎn)置)
分享URL:http://www.dlmjj.cn/article/djcsgjs.html


咨詢
建站咨詢
