溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用ByteArrayOutputStream實現將數據寫入本地文件

發布時間:2021-12-10 14:44:27 來源:億速云 閱讀:1675 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“如何使用ByteArrayOutputStream實現將數據寫入本地文件”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何使用ByteArrayOutputStream實現將數據寫入本地文件”這篇文章吧。

ByteArrayOutputStream將數據寫入本地文件

在一個項目中做一次性校驗部分,需要將校驗后數據寫入表格后上傳。巧的是,服務器Down了。作為一個新手實習生菜鳥,為了測試自己的代碼和輸出結果有沒有毛病,在大神同事的指點下選擇了先將表格輸出到本地

于是在百度瘋狂搜索“輸出流”、“輸出文件到本地”、“文件流”等,經過多方搜集和探查以及加工,最后加上了一小段代碼

//測試-將表格導入本地文件
        FileOutputStream fileOutputStream = null;
        try {
            fileOutputStream = new FileOutputStream("C:\\Users\\Administrator.DESKTOP-SFAEOA8\\Desktop\\consistencyCheckCommodityRuleTemplate.xlsx");
            fileOutputStream.write(byteArrayOutputStream.toByteArray());
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

以下是上傳Excel的部分代碼。將最后的上傳文件到dfs的方法注掉,以在準備好的文件 C:\\Users\\Administrator.DESKTOP-SFAEOA8\\Desktop\\consistencyCheckCommodityRuleTemplate.xlsx 中輸出需要的結果

public void uploadExcel() {
 
        //獲取校驗數據
        List<DTO> consistencyCheck = getConsistencyCheck();
 
        //創建模板信息
        DataModel dataModel = setDataModel();
        ......(此處省略一萬字)
 
        //創建ExcelData
        ExcelData excelData = setExcelData();
        ......(此處也省略一萬字)
 
        //創建日志數據
        ConsistencyCheckLog consistencyCheckLog = setConsistencyCheckLog();
        ......(此處又省略一萬字)
 
        //創建excel
        ByteArrayOutputStream  byteArrayOutputStream = createExcel(dataModel, excelData);
 
        //測試-將表格導入本地文件
        FileOutputStream fileOutputStream = null;
        try {
            fileOutputStream = new FileOutputStream("C:\\Users\\Administrator.DESKTOP-SFAEOA8\\Desktop\\consistencyCheckCommodityRuleTemplate.xlsx");
            fileOutputStream.write(byteArrayOutputStream.toByteArray());
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
 
        //上傳excel(無法上傳 先注掉好了)
        //uploadFileToDfs(consistencyCheckLog, byteArrayOutputStream);
    }

這樣就OK了,只添加了測試的部分,得到數據后也是放下了這顆菜心

那來了解一下ByteArrayOutPutStream吧

  • ByteArrayOutputStream類是在創建它的實例時,程序內部創建一個byte型別數組的緩沖區,然后利ByteArrayOutputStream和ByteArrayInputStream的實例向數組中寫入或讀出byte型數據

  • 字節數組輸出流在內存中創建一個字節數組緩沖區,所有發送到輸出流的數據保存在該字節數組緩沖區

  • 成功創建字節數組輸出流對象后,可以參見以下列表中的方法,對流進行寫操作或其他操作

序號方法描述
1public void reset() 將此字節數組輸出流的 count 字段重置為零,從而丟棄輸出流中目前已累積的所有數據輸出。
2public byte[] toByteArray() 創建一個新分配的字節數組。數組的大小和當前輸出流的大小,內容是當前輸出流的拷貝。
3public String toString() 將緩沖區的內容轉換為字符串,根據平臺的默認字符編碼將字節轉換成字符。
4public void write(int w) 將指定的字節寫入此字節數組輸出流。
5public void write(byte []b, int off, int len) 將指定字節數組中從偏移量 off 開始的 len 個字節寫入此字節數組輸出流。
6public void writeTo(OutputStream outSt) 將此字節數組輸出流的全部內容寫入到指定的輸出流參數中。

在表格輸出時

Java輸出流FileOutputStream也發揮了至關重要的作用

使用FileOutputStream寫入文件的過程同使用FileInputStream過程相同,都是先用File類打開本地文件,實例化輸入輸出流,然后調用流的讀寫方法讀取或寫入數據,最后關閉流。

FileOutputStream的寫入方法

FileOutputStream類提供了多種文件寫入方法,可以單獨寫一個字節到文件,也可以寫一個byte數組到文件,也可以取byte數組的部分數據寫入到文件。

把讀取的結果寫入到ByteArrayOutputStream

  • FileOutputStream 可以把數據寫到文件中去

  • ByteArrayOutputStream 可以把其他地方的讀入的數據寫到這里面,最后獲取數據所有的 byte[],相當于可以把數據全部讀到內存中來.

 // 把讀取的結果寫入到ByteByteArrayOutputStream
 public static void main(String[] args) throws IOException {
  // TODO Auto-generated method stub
  String s = "C:\\a.txt";
  int len = 0;
  FileInputStream stream = new FileInputStream(s);
  ByteArrayOutputStream stream2 = new ByteArrayOutputStream();
  byte[] buffer = new byte[5];
  //先讀后寫,循環讀寫
  while ((len = stream.read(buffer)) != -1) {
   stream2.write(buffer, 0, len);
  }
  byte[] data = stream2.toByteArray();
  System.out.println(new String(data));
 }

以上是“如何使用ByteArrayOutputStream實現將數據寫入本地文件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女