日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
優(yōu)雅解決:Linux行列轉(zhuǎn)置技巧簡析(linux行列轉(zhuǎn)置)

在日常開發(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