HBase shell 中的十六进制数值表示
2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>
在使用Hbase shell 進(jìn)行g(shù)et 或scan操作時(shí),時(shí)不時(shí)會(huì)看到一些數(shù)值被轉(zhuǎn)成了16進(jìn)制, 就像下面那樣
value=W\x5C5\x80
那么這個(gè)值具體等于多少? 查閱資料后發(fā)現(xiàn)算法如下
W -> W的ASCII碼16進(jìn)制 為 0x57
\x5C -> 就是16進(jìn)制不變 0x5C
5 -> 5的ASCII碼16進(jìn)制 為 0x35
\x80 -> 就是16進(jìn)制不變 0x80
所以從左往右重新拼起來(lái)就是
0x575C3580 -> 轉(zhuǎn)成十進(jìn)制為 ?1465660800
?
所以照例,如下
value=W]PA
W -> W的ASCII碼16進(jìn)制 為 0x57
] -> ]的ASCII碼16進(jìn)制 為 0x5D
P -> P的ASCII碼16進(jìn)制 為 0x50
A -> A的ASCII碼16進(jìn)制 為 0x41
0x575D5041 -> 轉(zhuǎn)成十進(jìn)制為 ?1465733185
?
?
?
以上是查詢結(jié)果出現(xiàn)十六進(jìn)制的情況, 那么如果查詢的Key本身也被轉(zhuǎn)為16進(jìn)制怎么辦? 因?yàn)橛袝r(shí)候key中可能有中文字符.
可以照如下操作:
先寫(xiě)個(gè)簡(jiǎn)單測(cè)試程序把中文UTF-8轉(zhuǎn)成16進(jìn)制
System.out.println(org.apache.commons.codec.binary.Hex.encodeHex("中文".getBytes("UTF-8"))); //輸出結(jié)果:e4b8ade69687System.out.println(new String(org.apache.commons.codec.binary.Hex.decodeHex("e4b8ade69687".toCharArray()),"UTF-8")); //輸出結(jié)果:中文也可以直接使用網(wǎng)站工具
https://sites.google.com/site/nathanlexwww/tools/utf8-convert
轉(zhuǎn)好后把16進(jìn)制每2位一組前面加上\x
就比如上面的
e4b8ade69687 ->?\xe4\xb8\xad\xe6\x96\x87?
?
舉個(gè)例子:?
我要查詢的key是
CE20CCE09EEB4F8A6BB50E41953A55FCD|3|鋼鐵烈陽(yáng)37|PA-1453442402-6111|PR-1453442402-3599
直接
get 'role_history_info' , 'CE20CCE09EEB4F8A6BB50E41953A55FCD|3|鋼鐵烈陽(yáng)37|PA-1453442402-6111|PR-1453442402-3599'
沒(méi)有結(jié)果
把其中的中文字符按照上面的方法轉(zhuǎn)成如下
鋼鐵烈陽(yáng)->e992a2e99381e78388e998b3 ->?\xe9\x92\xa2\xe9\x93\x81\xe7\x83\x88\xe9\x98\xb3
查詢時(shí) 包著key的單引號(hào)換成雙引號(hào)
get 'role_history_info' , "CE20CCE09EEB4F8A6BB50E41953A55FCD|3|\xe9\x92\xa2\xe9\x93\x81\xe7\x83\x88\xe9\x98\xb337|PA-1453442402-6111|PR-1453442402-3599"
?
查出來(lái)啦...
轉(zhuǎn)載于:https://my.oschina.net/sniperLi/blog/1616459
總結(jié)
以上是生活随笔為你收集整理的HBase shell 中的十六进制数值表示的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: shell中的$()、${}、$(())
- 下一篇: 算法笔记--数列分块