python - 使用happybase扫描带有中文字符的HBase表时过滤器不起作用

标签 python hbase thrift happybase

我在 HBase 中有一个表,其中汉字存储在特定列中,比如“FLT:CREW_DEPT”。现在我需要过滤掉“FLT:CREW_DEPT”等于某个值的所有行。在 hbase shell 中执行此操作时,它工作正常,如下所示

scan 'PAX_EXP_FACT', {COLUMNS => ['FLT:CREW_DEPT'], FILTER => "SingleColumnValueFilter ('FLT', 'CREW_DEPT', =, 'binary:\xe4\xb8\x80\xe9\x83\xa8', true, true)", LIMIT => 5}
ROW                                                  COLUMN+CELL
 CA101-20160808-PEK-001192753702                     column=FLT:CREW_DEPT, timestamp=1500346136328, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161103-PEK-001181988752                     column=FLT:CREW_DEPT, timestamp=1500346230204, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161105-PEK-000728690130                     column=FLT:CREW_DEPT, timestamp=1500346244963, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161201-PEK-006731936575                     column=FLT:CREW_DEPT, timestamp=1500346233640, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161212-PEK-001512808262                     column=FLT:CREW_DEPT, timestamp=1500346223572, value=\xE4\xB8\x80\xE9\x83\xA8
5 row(s) in 0.0060 seconds

然而,当使用 happybase 在 python 中做类似的事情时,没有任何返回:

import happybase
import datetime
import pytz

connection = happybase.Connection('192.168.199.200', port=9090)
table = connection.table('PAX_EXP_FACT')

filter_str = ""
filter_str += "SingleColumnValueFilter('FLT', 'CREW_DEPT', =, 'binary:\xe4\xba\x8c\xe9\x83\xa8')"

results = table.scan(
    filter=filter_str
    #     ,limit=100
)

count = 0
for key, data in results:
    count += 1
    print(data[b'FLT:CREW_DEPT'].decode('utf-8'))

print('No. of flight matches:', count)

connection.close()

返回 0 行 ...

有人可以帮忙吗?非常感谢!!!

最佳答案

答案原来很简单……我应该用过

"SingleColumnValueFilter('FLT', 'CREW_DEPT', =, 'binary:中文')"

而不是先将它转换为 utf-8 编码的字节字符串......即使在 hbase shell 中我也可以做同样的事情(尽管它显示在问号中)

scan 'PAX_EXP_FACT', {COLUMNS => ['FLT:CREW_DEPT'], FILTER => "SingleColumnValueFilter ('FLT', 'CREW_DEPT', =, 'binary:??', true, true)", LIMIT => 5}
ROW                                                  COLUMN+CELL
 CA101-20160808-PEK-001192753702                     column=FLT:CREW_DEPT, timestamp=1500353334419, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161103-PEK-001181988752                     column=FLT:CREW_DEPT, timestamp=1500353426641, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161105-PEK-000728690130                     column=FLT:CREW_DEPT, timestamp=1500353447707, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161201-PEK-006731936575                     column=FLT:CREW_DEPT, timestamp=1500353432222, value=\xE4\xB8\x80\xE9\x83\xA8
 CA101-20161212-PEK-001512808262                     column=FLT:CREW_DEPT, timestamp=1500353417107, value=\xE4\xB8\x80\xE9\x83\xA8
5 row(s) in 0.0100 seconds

使用 substring 是行不通的,这是我在提出这个愚蠢的问题之前一直在尝试的...

关于python - 使用happybase扫描带有中文字符的HBase表时过滤器不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45157503/

相关文章:

python - Numpy 多维数组中的索引顺序

java - 如何创建TBase类实例

python - 导入错误 : No module named happybase

java - 从 HBase 中检索除特定列族的值之外的所有内容

hadoop - 如何中止/回滚 HBase 待处理程序?

hadoop - 如何使用条件(Where 子句)从 HBase 执行简单选择

groovy - Gradle Thrift 插件示例

python - 当涉及无穷大值时, Pandas 滚动返回 NaN

python - 如何使 macports python 使用自己的软件包而不是其他安装的软件包?

python - 如何正确使用带有包含间隔的多索引的 Pandas Dataframe?