Android利用POI實(shí)現(xiàn)將圖片插入到Excel
問題
前兩天有個(gè)小工具的開發(fā),實(shí)現(xiàn)自動(dòng)化將Excel中的圖片鏈接Down下來然后插入到Excel表格中。朋友一直維護(hù)著任務(wù)類的(就那種打分評(píng)分啊,刷好評(píng)啊那些)。她量大,需要審核,靠人力實(shí)在是勞累。所以我研究了自動(dòng)化。
解決
實(shí)現(xiàn)插入圖片有兩種方式
方式一
直接插入到指定單元格,該方式適用于 Java 端,也就是在 PC上用,Android 因?yàn)槿鄙?resize的內(nèi)容會(huì)報(bào)錯(cuò)。博主沒找那么多資料看如何解決,我就直接用了方式二,支持Android的。
/** * @param workbook workbook對(duì)象 * @param sheet 工作簿對(duì)象 * @param fileUrl URL * @param row 第多少行 * @param col 第多少列 * @param scaleX X軸 * @param scaleY Y軸 */ public static void picture2(Workbook workbook, Sheet sheet, String fileUrl, int row, int col, double scaleX, double scaleY) { try { //防止URL地址有中文,解碼 String head = fileUrl.substring(0, fileUrl.lastIndexOf("/")+1); String suffix = fileUrl.substring(fileUrl.lastIndexOf("/")+1); String link = head + URLEncoder.encode(suffix,"UTF-8"); URL url = new URL(link); // 構(gòu)造URL URLConnection con = url.openConnection(); // 打開連接 con.setConnectTimeout(8 * 1000); //設(shè)置請(qǐng)求超時(shí) InputStream is = con.getInputStream(); // 輸入流 byte[] bytes = IOUtils.toByteArray(is); @SuppressWarnings("static-access") int pictureIdx = workbook.addPicture(bytes, workbook.PICTURE_TYPE_PNG); //參數(shù)二是圖片格式 還有jpg格式等 CreationHelper helper = workbook.getCreationHelper(); Drawing drawing = sheet.createDrawingPatriarch(); ClientAnchor anchor = helper.createClientAnchor(); anchor.setCol1(col); // 圖片插入坐標(biāo) anchor.setRow1(row); Picture pict = drawing.createPicture(anchor, pictureIdx); // 插入圖片 pict.resize(scaleX, scaleY); // 這個(gè)方法在 Android 端會(huì)造成崩潰。 } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } }
方式二
雖然復(fù)雜點(diǎn),但是無論是多端還是定制性都更強(qiáng)一些。該方式是插入坐標(biāo),坐標(biāo)稍微復(fù)雜些。
public static void picture(Workbook workbook, Sheet sheet, String fileUrl, String fileType, int row, int col) { try { Drawing patriarch = sheet.createDrawingPatriarch(); URL url = new URL(fileUrl); // 構(gòu)造URL URLConnection con = url.openConnection(); // 打開連接 con.setConnectTimeout(8 * 1000); //設(shè)置請(qǐng)求超時(shí) InputStream is = con.getInputStream(); // 輸入流 ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream(); BufferedImage bufferImg = ImageIO.read(is); ImageIO.write(bufferImg, "JPEG", byteArrayOut); bufferImg.flush(); byteArrayOut.flush(); XSSFClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0,( short ) 0, 0, ( short ) 5, 8); patriarch.createPicture(anchor, workbook.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG)); //參數(shù)二是圖片格式 還有png格式等 } catch (Exception e) { e.printStackTrace(); } }
主要解釋一下定位圖片位置函數(shù) ClientAnchor 的八個(gè)參數(shù)int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2
前四個(gè)表示的是 excel 邊框的內(nèi)距離,我們通常情況下都是0。
重點(diǎn)要看后四個(gè)參數(shù)
short col1, int row1, short col2, int row2
前兩個(gè)表示圖片左上角所在的單元格左上角的位置,這個(gè)不難理解。
后兩個(gè)表示圖片右下角所在的單元格左上角的位置,這個(gè)要特別留意。
橫向的 A B C D列 是從0開始數(shù)的,圖中 C是 2 豎著的是 4 ,自然起始左上角就是 2 ,4 。 右下角是同理
到此這篇關(guān)于Android利用POI實(shí)現(xiàn)將圖片插入到Excel的文章就介紹到這了,更多相關(guān)Android圖片插入Excel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android開發(fā)之ListView列表刷新和加載更多實(shí)現(xiàn)方法
這篇文章主要介紹了Android開發(fā)之ListView列表刷新和加載更多實(shí)現(xiàn)方法,實(shí)例分析了ListView列表操作的相關(guān)技巧,需要的朋友可以參考下2015-06-06Android開發(fā)中自定義ProgressBar控件的方法示例
這篇文章主要介紹了Android開發(fā)中自定義ProgressBar控件的方法,結(jié)合實(shí)例形式分析了自定義ProgressBar控件的定義與使用方法,需要的朋友可以參考下2017-10-10Android實(shí)現(xiàn)三段式滑動(dòng)效果
最近發(fā)現(xiàn)很多app都使用了三段式滑動(dòng),比如說高德的首頁和某寶等物流信息都是使用的三段式滑動(dòng)方式,谷歌其實(shí)給了我們很好的2段式滑動(dòng),就是BottomSheet,所以這次我也是在這個(gè)原理基礎(chǔ)上做了一個(gè)小小的修改來實(shí)現(xiàn)我們今天想要的效果。2021-06-06Android自定義view利用PathEffect實(shí)現(xiàn)動(dòng)態(tài)效果
這篇文章主要為大家詳細(xì)介紹了Android自定義view利用PathEffect實(shí)現(xiàn)動(dòng)態(tài)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05Android自定義控件實(shí)現(xiàn)通用驗(yàn)證碼輸入框(二)
這篇文章主要為大家詳細(xì)介紹了Android自定義控件實(shí)現(xiàn)通用驗(yàn)證碼輸入框的第二篇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01android編程實(shí)現(xiàn)系統(tǒng)圖片剪裁的方法
這篇文章主要介紹了android編程實(shí)現(xiàn)系統(tǒng)圖片剪裁的方法,涉及Android針對(duì)圖片的獲取、修改、保存等操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11Android音視頻開發(fā)之MediaPlayer使用教程
Android多媒體框架支持播放提供了MediaPlayerAPI,可以通過MediaPlayer來實(shí)現(xiàn)媒體文件播放??梢哉fMediaPlayer是非常方便使用的多媒體播放器。本文將詳細(xì)講解MediaPlayer的使用,需要的可以參考一下2022-04-04Android開發(fā)懸浮按鈕 Floating ActionButton的實(shí)現(xiàn)方法
這篇文章主要介紹了Android開發(fā)懸浮按鈕 Floating ActionButton的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09