在打字稿中访问 Apache Arrow Table 扫描中的值

问题描述

在 Chrome 中使用 typescript scan创建 Apache Arrow 3.0.0 表时,我无法访问值。

用熊猫创建了一个简单的测试箭头文件

import pandas
test = pandas.DataFrame({
  "text": ["foo","bar","baz"],"dicttext": ["a","a","b"],"numbers": [1,2,3]}
)
test["dicttext"] = test["dicttext"].astype("category")
test.to_feather("test.arrow")

下面的代码跟在 Introduction to Apache Arrow 后面。

  const textCol = arrow.predicate.col("text");
  const dicttextCol = arrow.predicate.col("dicttext");
  const numbersCol = arrow.predicate.col("numbers");

  let textf: any,dicttextf: any,numbersf: any;
  table.scan(
    (idx) => {
      const text = textf(idx);
      const dicttext = dicttextf(idx);
      const number = numbersf(idx);
      console.log(
        `idx=${idx} text=[${text}] dicttext=[${dicttext}] number=${number}`
      );
    },(batch) => {
      // create accessor functions
      textf = textCol.bind(batch);
      dicttextf = dicttextCol.bind(batch);
      numbersf = numbersCol.bind(batch);
    }
  );

控制台输出为:

idx=0 text=[] dicttext=[] number=24
idx=1 text=["M`@foobarbaz] dicttext=[] number=1405756815161762308
idx=2 text=[] dicttext=[] number=281479842103296

idx=1 行稍作修改删除无效字符)。

该改变什么来访问原始值,或者在分类列的情况下获取键?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...