日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

hive之反斜杠导致Unicode编码字段里的中文无法正常显示

發布時間:2023/12/8 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hive之反斜杠导致Unicode编码字段里的中文无法正常显示 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

hive之反斜杠導致Unicode編碼字段里的中文無法正常顯示

從mysql拉到hive的ods的表中字段顯示不正常,如下

content字段中文無法顯示
首先利用在線unicode解析看下具體的中文內容是什么

**初始判定問題原因:**此時暫時判定是因為hive沒有成功將“unicode”編碼格式的字段轉化為“utf-8”,故而無法正常顯示
因為沒有找到合適的函數進行轉碼,所以自定義UDF,如下

import org.apache.commons.lang3.StringEscapeUtils; import org.apache.hadoop.hive.ql.exec.UDFArgumentException; import org.apache.hadoop.hive.ql.exec.UDFArgumentLengthException; import org.apache.hadoop.hive.ql.exec.UDFArgumentTypeException; import org.apache.hadoop.hive.ql.metadata.HiveException; import org.apache.hadoop.hive.ql.udf.generic.GenericUDF; import org.apache.hadoop.hive.serde2.objectinspector.ObjectInspector; import org.apache.hadoop.hive.serde2.objectinspector.primitive.PrimitiveObjectInspectorFactory; import org.apache.hadoop.io.Text;public class SelfUnicode extends GenericUDF {/**** @param arguments 輸入參數類型的鑒別器對象* @return 返回值類型的鑒別器對象* @throws UDFArgumentException*/public ObjectInspector initialize(ObjectInspector[] arguments) throws UDFArgumentException {// 判斷輸入參數的個數if(arguments==null ||arguments.length!=1){throw new UDFArgumentLengthException("函數的參數個數不正確!!!");}// 判斷輸入參數的類型if(!arguments[0].getCategory().equals(ObjectInspector.Category.PRIMITIVE)){throw new UDFArgumentTypeException(0,"函數參數類型不正確!!!");}//需要返回string類型的鑒別器對象return PrimitiveObjectInspectorFactory.writableStringObjectInspector;}/**** @param arguments* @return*///private final IntWritable intWritable = new IntWritable(0);private final Text result = new Text();public Object evaluate( DeferredObject[] arguments) throws HiveException {Object o = arguments[0].get();if(o==null){result.set("NULL");return result;}String str = o.toString();if(str.equals("")){result.set("字段值為空");return result;}String res_str="";try {res_str = URLDecoder.decode(str, "utf-8");} catch (UnsupportedEncodingException e) {e.printStackTrace();}result.set(res_str);return result;}public String getDisplayString(String[] strings) {return "";} }

上傳hdfs后,添加臨時函數,測試運行得結果

add jar hdfs:///user/hive/warehouse/auxlib/self_unicode-1.0-SNAPSHOT.jar; create temporary function my_unicode as 'com.atweimiao.unicodeudf.SelfUnicode'; select my_unicode('"question_id":1,"name":"\u8eab\u9ad8\u4f53\u91cd","tag":"\u8eab\u9ad8\u4f53\u91cd","type":1')


當我以為問題解決的時候,現實很骨感,竟然還是無法轉碼顯示

我以為代碼出了問題,換網絡IO的傳遞對象、換處理的方法,最終還是測試過程沒問題,唯獨解析不了字段,難受!
后來我將這堆字符串黏貼到java中發現了端倪,當這個函數處理字段的時候不是頁面顯示的樣子,其實處理過程多了很多的轉義字符‘\’

因為這些轉義字符,導致URLDecoder.decode(str, "utf-8")無法正確解析str字符串

**最終判定問題原因:**思考之后,其實是反斜杠的原因,導致無法進行解析字符串

故而,使用org.apache.commons.lang3.StringEscapeUtils里的unescapeJava方法可以實現反轉義

使用hive的函數reflect()有時可以實現自定義UDF的一些功能的,所以使用reflect

reflect('org.apache.commons.lang3.StringEscapeUtils', 'unescapeJava',content)

測試運行如下,成功轉碼顯示

總結

以上是生活随笔為你收集整理的hive之反斜杠导致Unicode编码字段里的中文无法正常显示的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产乱码精品 | 麻豆精品视频在线观看 | 国产欧美久久久精品免费 | 特黄特色大片免费视频大全 | 色婷婷精品| 精品国产一二三区 | 狠狠噜噜 | 国产在线a | 成人午夜一区二区 | 黄色片视频免费观看 | 免费黄色网址在线 | 五月天开心网 | √资源天堂中文在线 | 亚洲熟妇一区二区三区 | av成人在线免费观看 | 国产黑丝一区二区 | 青青伊人久久 | 国产三级一区二区三区 | 不卡av一区| 蜜臀av一区二区三区有限公司 | 污片免费在线观看 | 羞视频在线观看 | 欧美一级久久 | 黄色a级片在线观看 | 三级网站免费看 | 91精品综合久久久久久 | 四虎成人精品永久免费av | 青青草原国产在线 | 99re6在线观看 | 久操国产在线 | 日韩欧美一卡二卡 | 国产精品系列在线观看 | 亚洲精品国产精品乱码视色 | 亚洲国产精品毛片av不卡在线 | 日本人视频69式jzzij | 亚洲久久一区二区 | 欧美另类自拍 | 制服丝袜一区在线 | 日本黄色免费观看 | 在线成人亚洲 | 又污又黄的网站 | 最好看的电影2019中文字幕 | 激情影院内射美女 | 亚洲av成人无码一二三在线观看 | 91高清视频免费观看 | 日本一区二区免费电影 | www.-级毛片线天内射视视 | 亚洲一级色 | 蜜桃精品成人影片 | 亚洲4p | xxxx视频在线 | 年代下乡啪啪h文 | 精品国产aⅴ一区二区三区东京热 | 色女人影院 | www.午夜| 少妇在线 | 中文无码一区二区三区在线观看 | 国产美女主播在线 | 污污的视频在线免费观看 | 国产精品自拍av | 日韩不卡中文字幕 | 精品成人av| 国产视色 | 欧美在线视频播放 | 麻豆疯狂做受xxxx高潮视频 | 天天操天天操天天操天天操 | 国产福利视频一区 | 日日摸夜夜添狠狠添久久精品成人 | 国产青青视频 | 色超碰 | 天天5g天天爽免费观看 | 日韩v欧美 | 九九热九九 | 成人免费看高清电影在线观看 | gav在线| 看污片网站 | 福利精品视频 | 色噜噜综合网 | 一级欧美视频 | 最新黄色av | 91国产中文字幕 | 宅男午夜在线 | 在线观看免费成人 | 久久综合爱 | 国产在线一区二区视频 | 中文幕无线码中文字蜜桃 | 欧美劲爆第一页 | 久久久久久久亚洲 | www.奇米| 亚洲精品电影在线 | 国产精品911 | 欧美日韩免费做爰视频 | 超碰不卡 | 成人99 | 欧洲中文字幕日韩精品成人 | av在线综合网 | 国产免费的av | 欧美丰满美乳xxⅹ高潮www | 91看片在线观看 |