From 0f5be71e006bcea1a7e02f069c155bc62b293991 Mon Sep 17 00:00:00 2001 From: zhuangjiaju Date: Thu, 8 Aug 2019 13:16:06 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BC=98=E5=8C=96=E8=AF=BB=E5=86=99=E9=80=BB?= =?UTF-8?q?=E8=BE=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../write/longestMatchColumnWidthWrite.png | Bin 0 -> 6702 bytes quickstart.md | 51 ++++++++++++++++++ .../excel/context/WriteContextImpl.java | 4 +- .../easyexcel/test/demo/write/WriteTest.java | 3 ++ 4 files changed, 57 insertions(+), 1 deletion(-) create mode 100644 img/readme/quickstart/write/longestMatchColumnWidthWrite.png diff --git a/img/readme/quickstart/write/longestMatchColumnWidthWrite.png b/img/readme/quickstart/write/longestMatchColumnWidthWrite.png new file mode 100644 index 0000000000000000000000000000000000000000..c8a06049062bb982f35903212ff1834a918ab3a9 GIT binary patch literal 6702 zcmZu#2T+q;vqm8rsz3k{DWMp;AP}S}34~7QRVe`hAqa>F(xgNMqDYq#1Oie+FH)pK zs3J{}Q2c00k)|Ms6uB>c|GhK!&V4hPIlJfVo_%(o-MkaLk%1N?9Ty!H6&0h7Hp+yG ziUvnTb%qs84QOiFW8MM6l99fd#=y!Dg+gg-YXkHvD=TATV?8}RYWZp@DJdipDJ(3k ztt|`z>`_6fs1SgFA+{0!ssMFc8xhc9^p1EqpOp)s~7 z3Z=D;hzTRML7@ngZvh5_2@Au7VW0?1*ucO5B8*tziz+QGZ6k(JK@njHC<0-xrlwXv zp#V0uwY8K2Uj*<#shXRcD=I252q>jBh8PwGoW%fY1g5&Wx|Kp962n?!Y$=oilr6A} zK%snnQ79s@jZ7xn#sC2j|DJ}vd-ra5co>L)h(W}(Qu_M(pqQ}1!NIW81ArRgRNm9k z(eXH1Haa@m7UgSXWW9m^b7WKax%5(8Kw5L7)q$vVMU*)S(xlx=dV>>WSJvYwvDjXl0Gt!8P( zJ&liLqaPRe`o`G$QXw!-7v<{|=A<8{4`iqlZ0Alz#YwG$LYnzctxsNy z%|TE_IJENc&-|ehD;3pt)t66i9GudmyW?~1BePmf0afT>`;3zVzr1G+;A=<4Cszm?%d~xV49d&sDg4oX#csTOKc1-4mlrq9i>Xxhh;(?CY&+&u(6YIh? zlw4E*tx!y4&lQ-knBp+eiV1M9J(N+tu3WLklD_}{d*I6z#liOnk7Y<>??&b!w8 zi`d+d+SD})%6b#2W?z1CF;KJFjOGy%MLlyJnQr18^6e2)A@6+B`q+!d!6_}p%w5?t zenQ$~E4^$eW#l-@gFq|5wNgea7PBnetE6+6rz~Tp(TnCf^YzBP)4QSJuvo1#9? zLHN2Icl4JOM%^D8{R5FQSCOBq)h>)(*E%xJbY;kZ?kJ=V6H8I1p}426TAB}qwTD*2 zyU(#O=0G0W5ti05a;mSyk9vnSAkDn5h-7<0x8Zk0#8tw|ZXpdw{G%VuvU%8f8J`i9 zl=c-7U5gf-te)ytT>+Ii{0ms14t-J%)LTD+hK0AU7x0h+ii*mNpcTlOzJ^4}3F|Yn ze2xJmMF(8eiXR|-poO4NhND@~_po==!>?_7W@l4~y)c63d4jC_(eYziI***yKe#0c zuFz0>T#Wq4LocGDa!hNh6tV^VGd3e=%}oH@Ni{R66JcbvLQ6k34y%n&M?$T#^LW3p zJUNS7I1`2Mc9*vE&U<>_!3fC$X&%n{Hej@Nbz{)aL#JZrW?zI!i%Vaftk>PTbO9W~ zB@YTjxH+iFy9hVrTleO)^}z)3wME*fpY{R zCd*5!Z(x&&^E0g47GF62uXVh6!O*ipk|SMXXq^4a577N=J% zSKlM@YK|r+J4=zeohU)Be|Rz;ZIOT0TmA)|X2C!VDWxGy-oLSXX5kzQO%$|H!~MqY zH*mi!6^a>(n`?~#V?BE=A|_HfhY1?qPW}5=`K@?PBQaXmfEdVxPhE7 zGd*R@%DBqc5G9)VT9T)!)kkRWXI|OiZpjWG@3yj1jaFzf7%aIhFY z^~PYXHP~PzUPp;}JzZ|GR`sExriL<~$aN+yv+FNYvUG>@J~|i|U$JKy^NhIHoRkwB z6D8@ey;=7$I?LdFB+Ha(;L427)6wYs!`-r-@IN|m-PSC)IxUyw0L+}mqpVyI7tI;! zC3^YBz)o#n%;4n1D83T^+lOx}_+LK%l@&52-u-lPkyDesNa%ttj?Z3loDXRmd^uor zsF8C~eMYO`PWi`-GE>R+lnTP;MB|_rP2Yqu7N)*nZ!rMVp!wm|+%Bdq!PU6Fni21I zCxWcIzrh`wr7gP9MIEr;-zn&)NSQ#3zU0d=bv(nqWtcC_q1i>SRNmDX2F33LFY20( zY8A{DnEo={QGZLmi)i&B^;KhSe;uZ06bE^8fft4Y^w869Mf>vT8EdXsJPkn*pN(Ev zQO~}A!zfO97Nv;#-X(RAE0D90xYe?s^-g(GUdL2lUL%;ov-#jknp2?c?_)ndmqh&= z0d%+K^Je(l$`0f1dNC$wCT2!CKQBB0|CZ~XUi6!BI4@!w4Q^HM)uGcJqDYD2Uz#f{ z6e?a+mZi^eUxL3*1#2(u%4x=c9{$-TyLvIUTYU1YwF{SsG6ZKMzX$I7esmpuOH@%? z9RNGiyGYtGk|IhgF+-~rY>>(zgCsRe(!#@=O!Y!s#hbX*4-*93^Ko1>uiAq?ac}q~ zLqSdheFZ!8Ii6P=E^B>;z!M_ji>|73A!l9C8jS%zzlaompfbHaYjr&&_IekWsN8CPQ&N(KRFX;j z+f8w|$cRNjo465mEZ1`mH6G$NHLpZB-)8ET-P83}!wjUU(KR~VyCBxg+FSf%|NI`( zJ=Q=72s)pnb@=(L>KMmqT#w?~s~Z%K+|!YBqw8nW)3@#Nm!?S-q&}l(UAJfujZ@1k z*SZbUZ+?KjWZ&Fu8X%BtG0eEsc#nE``0L678{4?1kjjmx%-9RTSrsBTV=lP`!hJVf zR@v90Jlcc(zuMMh6s)TijO2=HbI^($i?8#{wX_-=O&|K5r*^NNUX`_ol`ih??tG~V zIvk}WjV11gxW2-gEdTl`xaCp!Xyj?ZAQ2+lA%E3)+%ws(GKRC2xBS6vNul~LszsJs zSx98^4*_mZf`DR-d1RpD3$_}b$4=prFJ_e@_}2-3Jc;F$?PT4XNIy^07CBk)XN(>d zf7Kg)Gm{WW&GQT;w8IKaq!7yD8=^!A2wCg?^?6?AB6 zd8TP8+(TykyUQ76mBizxd?oz#;|UKQaDe88Q-8H}^MG||4Y#tp7vQS$qcpNc6Q0SL zDj@4R(=fV(RO^pyKQD-gSjWUfsWwm+im$8EP+YRQXDuOq4_e`Eip|e2xV@fEYNcna zdf3Y3jphVm=hrGdMp(D_w}CJ1}H(YT;sGnQKAr zXVSaVef}Xrv~lUC-_0CWkfkRrDty4qvz`HBqAyHadOUU3h9K~%b^Y8K`_i**%!Rq1 zxdRi}Y6$DRNfNVJsjZY()M#W^*OZc#p`NkPNnM?uiP26fZr`mgapmWw*4tO>ESZQa zcgZrjO`P$Rer1X6Rz(%7$*i-fa9Tsbu@Vda(Wy1N7t%aNb=%bNjir&q9O88GSKk^M zSMZ$Qg6k-o5I^V1n_mYEjr=dmW4j~r?+T0dUMbw%;LG@BpTd^1EYhWp6#dii1Mjc( zI;ntVAr&q(n{947;~8N$UkBSO$oZ<~b{2i`$~lyxoIV!e0HqUGLG^*Eyf`NFiig#* z)00i!t)F?f-ZHW3p~p5Kf5i5FO!e7Funu=ni9cd5s9%Bk(n)s;Iy*Z?i+;Y2ieyu~KcVX?Q*L*9<}Ux<_dOFa z^6-rZ8xu;**tB_SDJPC%*8TR^&3oK8PSJHu^;s>HL2Jc zXoOmQ_3y&PJX2#x6XL&PMf0;1fiU!Qn{Q8G;~FToW-S6``^P8vM#t==&Fyhde4ce* z40t_w*0TxJ+>#~#R!!ntRj}97t&lHon2LTs*S>seb5mlXirD0nR~Mh_x!My(w`Ltz ze0%ts0<$%kX=}Oe4hK2{4yRfr7#*t zC+7uUf16RZ)rvt6vo7!ct*u0Yw&yET$nT-ayC;m=an4L`&o3=SM@+w=>GE3GHHH?r za5yzQw|ag4xew9}-lNJpB%|?dzp-_H_knFybNvA;oA7*)?gjF>7MWdRFU5YnxD1K@ z@>aVYRyOy(k%TR^5TG z9v3OPiLppI_7J9`#py50)wGvTU*#6kPWNX0x!q#Z@_9yOcN0I9;p@1S?tl3HEEPtr z7YC)cW|n5AW{-n<+(#$9C_cxUix#B~T(3K*tr2eieG4jH#Yo`=>MMf(xCm8xA98 z?kFT=w0cuH>X6ME*-KY7ftrYmZ_g;7O&n4_zrJVTlQwI(^eol*0jSaxP5zMgmCiAx z9=DWT2qVEX%b>-rxO{IB5}t&YYQU8o(A^5jc!70%(Qv=Z5FT$!Ak-i3E!vntiif_2 zN)rjaSM|`ZyB{cA94DXiS&e*(6=;-zdruxcfdEDu4LmA*rf8>>T-adGu`j3yR+~z1 zd1MBe{91_rsDQdWPVVDZicBgh1ME`j2B)#k^kc{Z#}TpM1w zH^Y=UTnMWIR0E(^SSg{`03I)MF`dt~0vLj*13%@{RM6SNsR_|^a14Fr-12&Ryf zdLWYjNG6asodItMRvw)T^w1$q;7iAvoQdg^hMpAL56=W_pqy&2^8z_VFi^S`-?un!F|0R&I3f2Fh=g&${Ol4GJ{+m z*l+`Cv#o0ac{J2>+F5P?(3kE>YVi)LOAq|B< zHQ&ST{kQ9dEUaUC!(2ERUL@0RLuTm{I&m2XQ?Bhs+pRq>$;9+CjIFBz%(zfXjN> z!3cd%_G0h_Q}ol69GK^cx;nhF-Dcm*8OV(&c44o_^)IjYOG|+CX`p8|9Z2|JnbT_k z$8wXiVVVX0y!nLGn-ecmu>$Yp;MX!Efh#ko+aX+l0}?)};Y)dc(J9Sy2fCK%xz@=_ z>#@tHcwAj#2?fx`v;ydkfJ+ikcQc5$k6Qzdl2=MBN}5PP!j0iS2;#kB<;4BaZGgYn z1w){r8*xmBp`8^+tw6;H??0pdEszJOv>NO9q~XVtAo0^C%Y*TjU#v7fb@7OVw=hJj zypkco{x$a`p>AZ>;@BLOrq=KaQTA=Sq zU;JaP2zb}QIyU78h5%Lml=(i?0r8)>XHN&pADef?yuUR%;(wnHB)mkqF0$YbkRPDX z!%DipDO;!A@eFbcP$i6!SB?~mVHTOw;R^+S8zb6akw~x#@I3!K3m^|0{2HB{@n0%v zsR7p{6BJ%;%U>YjA7xE1ivkHt#|k)J{k;PW&41^X)Ze)!TMh6lKTa0Q4CRv=S0~|l zmdoZQpJE;5(Ik99^N`IfFd^4(JYod;BRUTauM{iHhX{|8XEPcHZ2_lONq82Yk9=Ci zu%#SAs?2o`K36BfPvPQ`xGG~b&HZ8uXkNe%d7oLG?ldKiGc$4`BI)_#1avXFW zVb}#XbD;Yrp5cZY0m_o_)Jx~mwSk~q#>vj+=yjFrN7Yxx$@d86kQDP%{zqX2lq~-5 zy7F-5pm8h`atgl~cC{Gm_^V;}LUN#CAT@=Bko&|wV7GTQpNZUtEt)xv}(BhK=_Cq^F`VY gr%Q@LBEWlWMo!*<&7uu|I~DNgXc(Z%)G)aJ0)Kgni2wiq literal 0 HcmV?d00001 diff --git a/quickstart.md b/quickstart.md index 4b2d4ac1..3a7fd41e 100644 --- a/quickstart.md +++ b/quickstart.md @@ -22,6 +22,7 @@ DEMO代码地址:[https://github.com/alibaba/easyexcel/blob/master/src/test/ja * [合并单元格](#mergeWrite) * [使用table去写入](#tableWrite) * [动态头,实时生成头写入](#dynamicHeadWrite) +* [自动列宽(不太精确)](#longestMatchColumnWidthWrite) * [web中的写](#webWrite) ## 读excel样例 @@ -739,6 +740,56 @@ public class WidthAndHeightData { } ``` +### 自动列宽(不太精确) +##### excel示例 +![img](img/readme/quickstart/write/longestMatchColumnWidthWrite.png) +##### 对象 +```java +@Data +public class LongestMatchColumnWidthData { + @ExcelProperty("字符串标题") + private String string; + @ExcelProperty("日期标题很长日期标题很长日期标题很长很长") + private Date date; + @ExcelProperty("数字") + private Double doubleData; +} +``` +##### 代码 +```java + /** + * 自动列宽(不太精确) + *

+ * 这个目前不是很好用,比如有数字就会导致换行。而且长度也不是刚好和实际长度一致。 所以需要精确到刚好列宽的慎用。 当然也可以自己参照 + * {@link LongestMatchColumnWidthStyleStrategy}重新实现. + *

+ * poi 自带{@link SXSSFSheet#autoSizeColumn(int)} 对中文支持也不太好。目前没找到很好的算法。 有的话可以推荐下。 + * + *

  • 1. 创建excel对应的实体对象 参照{@link DemoData} + *
  • 3. 注册策略{@link LongestMatchColumnWidthStyleStrategy} + *
  • 2. 直接写即可 + */ + @Test + public void longestMatchColumnWidthWrite() { + String fileName = + TestFileUtil.getPath() + "longestMatchColumnWidthWrite" + System.currentTimeMillis() + ".xlsx"; + // 这里 需要指定写用哪个class去读,然后写到第一个sheet,名字为模板 然后文件流会自动关闭 + EasyExcelFactory.write(fileName, LongestMatchColumnWidthData.class).sheet("模板").doWrite(dataLong()); + } + + private List dataLong() { + List list = new ArrayList(); + for (int i = 0; i < 10; i++) { + LongestMatchColumnWidthData data = new LongestMatchColumnWidthData(); + data.setString("测试很长的字符串测试很长的字符串测试很长的字符串" + i); + data.setDate(new Date()); + data.setDoubleData(1000000000000.0); + list.add(data); + } + return list; + } +``` + ### web中的写 ##### 示例代码 DEMO代码地址:[https://github.com/alibaba/easyexcel/blob/master/src/test/java/com/alibaba/easyexcel/test/demo/web/WebTest.java](/src/test/java/com/alibaba/easyexcel/test/demo/web/WebTest.java) diff --git a/src/main/java/com/alibaba/excel/context/WriteContextImpl.java b/src/main/java/com/alibaba/excel/context/WriteContextImpl.java index 18331305..ff2215e0 100644 --- a/src/main/java/com/alibaba/excel/context/WriteContextImpl.java +++ b/src/main/java/com/alibaba/excel/context/WriteContextImpl.java @@ -117,7 +117,9 @@ public class WriteContextImpl implements WriteContext { throw new IllegalArgumentException("Sheet argument cannot be null"); } if (writeSheet.getSheetNo() == null || writeSheet.getSheetNo() <= 0) { - LOGGER.info("Sheet number is null"); + if (LOGGER.isDebugEnabled()) { + LOGGER.debug("Sheet number is null"); + } writeSheet.setSheetNo(0); } if (writeWorkbookHolder.getHasBeenInitializedSheet().containsKey(writeSheet.getSheetNo())) { diff --git a/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java b/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java index d105fb76..8b5fae8b 100644 --- a/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java +++ b/src/test/java/com/alibaba/easyexcel/test/demo/write/WriteTest.java @@ -7,6 +7,7 @@ import java.util.List; import org.apache.poi.ss.usermodel.FillPatternType; import org.apache.poi.ss.usermodel.IndexedColors; +import org.apache.poi.xssf.streaming.SXSSFSheet; import org.junit.Ignore; import org.junit.Test; @@ -243,6 +244,8 @@ public class WriteTest { *

    * 这个目前不是很好用,比如有数字就会导致换行。而且长度也不是刚好和实际长度一致。 所以需要精确到刚好列宽的慎用。 当然也可以自己参照 * {@link LongestMatchColumnWidthStyleStrategy}重新实现. + *

    + * poi 自带{@link SXSSFSheet#autoSizeColumn(int)} 对中文支持也不太好。目前没找到很好的算法。 有的话可以推荐下。 * *

  • 1. 创建excel对应的实体对象 参照{@link DemoData} *
  • 3. 注册策略{@link LongestMatchColumnWidthStyleStrategy}