AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 79464748
Accepted
CleanSock
CleanSock
Asked: 2025-02-25 04:37:30 +0800 CST2025-02-25 04:37:30 +0800 CST 2025-02-25 04:37:30 +0800 CST

KDB 中用于修改 col 值的代码行数更少

  • 772

我有一张如下表:

q)tab:([]time:.z.t;sym:`ax`bx`cx`ds;col1:`a`a`b`b;price:1.4,1.2,1.3,1.4)
q)tab
time         sym col1 price
---------------------------
20:29:37.309 ax  a    1.4
20:29:37.309 bx  a    1.2
20:29:37.309 cx  b    1.3
20:29:37.309 ds  b    1.4
q)

我的目标是将 col1 中的值从 a->b(其中 a 和 b->a(其中 b 和列名相同))更改为 a->b(其中 b 和列名相同)。下面是我的代码,可以完成这项工作,但是有没有更好的方法可以用更少的代码行来实现这一点?

testTab:update col2:count[i]#enlist `b from tab where col1=`a
testTab:update col2:count[i]#enlist `a from testTab where col1=`b

q)testTab
time         sym col1 price col2
--------------------------------
20:29:37.309 ax  a    1.4   b
20:29:37.309 bx  a    1.2   b
20:29:37.309 cx  b    1.3   a
20:29:37.309 ds  b    1.4   a
q)testTab:`time`sym`col2 xcols testTab  //Bring forward col2

q)testTab
time         sym col2 col1 price
--------------------------------
20:29:37.309 ax  b    a    1.4
20:29:37.309 bx  b    a    1.2
20:29:37.309 cx  a    b    1.3
20:29:37.309 ds  a    b    1.4

q)testTab: delete col1 from testTab    //Delete original col1 from the table
q)testTab: `time`sym`col1 xcol testTab  // Rename col2 to col1

q)testTab
time         sym col1 price
---------------------------
20:29:37.309 ax  b    1.4
20:29:37.309 bx  b    1.2
20:29:37.309 cx  a    1.3
20:29:37.309 ds  a    1.4
q)

谢谢!

kdb+
  • 1 1 个回答
  • 35 Views

1 个回答

  • Voted
  1. Best Answer
    terrylynch
    2025-02-25T05:03:29+08:002025-02-25T05:03:29+08:00

    最简单的方法是使用字典/地图:

    q)map:`a`b!`b`a
    q)
    q)update map col1 from tab
    time         sym col1 price
    ---------------------------
    21:01:27.484 ax  b    1.4
    21:01:27.484 bx  b    1.2
    21:01:27.484 cx  a    1.3
    21:01:27.484 ds  a    1.4
    

    如果不是所有值都要改变(即只有子集需要重新映射),那么只有改变的子集才应该在映射字典中,其余的可以^用现有值填充()

    update col1^map col1 from tab
    
    • 3

相关问题

  • 如何生成随机价格时间序列

  • 解释 KDB 中整数向量/字典的哪些部分适用

  • 如何在 Q/KDB+ 中应用基于 table_2 的每一行修改 table_1 的函数?

  • 获取列表中最后一个值为零的索引

  • 与更新一起使用的矢量化函数调用

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve