首页 > 编程问答 >Polars - 当/那么条件形成字典

Polars - 当/那么条件形成字典

时间:2024-07-26 15:55:41浏览次数:14  
标签:python python-polars

我想要一个函数,它接受条件列表作为参数,并按所有条件过滤给定的数据帧。 伪代码应该是这样的:

def Filter(df, conditions = ["a","b"]):
    conditions_dict = {
        "a":  pl.col("x") < 5,
        "b":  pl.col("x") > -3,
        "c":  pl.col("z") < 7
        }

    return df.with_columns(
        pl.when( any [conditions_dict[c] for c in conditions])
        .then(pl.lit(False))
        .otherwise(pl.lit(True))
        .alias("bool")
        )

怎么做?


import polars as pl

def filter_df(df, conditions=["a", "b"]):
    conditions_dict = {
        "a": pl.col("x") < 5,
        "b": pl.col("x") > -3,
        "c": pl.col("z") < 7,
    }

    # Dynamically create the condition using reduce
    cond = pl.reduce(lambda a, b: a & b, [conditions_dict[c] for c in conditions])

    return df.with_columns(
        pl.when(cond)
        .then(pl.lit(False))
        .otherwise(pl.lit(True))
        .alias("bool")
    )

# Sample DataFrame
df = pl.DataFrame({"x": [1, 2, 6, 4, -5], "z": [8, 3, 2, 6, 1]})

# Test the function
print(filter_df(df, ["a", "b"]))

说明:

  1. 动态条件构建:
  2. 我们使用 pl.reduce(lambda a, b: a & b, [conditions_dict[c] for c in conditions]) 来动态地将多个条件组合成一个条件。 reduce 函数依次应用 lambda 函数,将两个条件使用 & 运算符连接起来,最终生成一个组合条件。

  3. 应用条件:

  4. 我们在 pl.when(cond) 中使用动态构建的 cond 来应用过滤条件。

现在, filter_df 函数将根据提供的条件列表动态地过滤数据帧。

标签:python,python-polars
From: 78796866

相关文章

  • 使用Python实现深度学习模型:语言翻译与多语种处理
    引言语言翻译和多语种处理是自然语言处理(NLP)中的重要任务,广泛应用于跨语言交流、国际化应用和多语言内容管理等领域。通过使用Python和深度学习技术,我们可以构建一个简单的语言翻译与多语种处理系统。本文将介绍如何使用Python实现这些功能,并提供详细的代码示例。所需工具......
  • python框架之Flask
    之前写过有关flask-restful: https://www.cnblogs.com/xingxia/p/flask_restful.html虽然早期使用python进行web应用搭建的使用该框架,但是好像很少总结,在此记录一下 [安装]pip3installflask [使用]#导入类库fromflaskimportFlask#创建实例......
  • Python 搜索和抓取
    我有一个问题想知道是否值得花时间尝试用Python来解决。我有一个包含鱼类学名的大型CSV文件。我想将该CSV文件与大型鱼类形态信息数据库(www.fishbase.ca)交叉引用,并让代码返回每条鱼的最大长度。基本上,我需要创建代码来搜索Fishbase网站上的每条鱼,然后找到页面上的最......
  • 《最新出炉》系列入门篇-Python+Playwright自动化测试-54- 上传文件(input控件) - 上篇
    1.简介在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等。所以宏哥打算按上传文件的分类对其进行一下讲解和分享。2.上传文件的API(input控件)Playwright是一个现代化的自动化测试工具,它支持多种浏览器和操作系统,可以帮助开发人员和......
  • python requests 报错 Caused by ProxyError ('Unable to connect to proxy', OSError
    背景:访问https接口,使用http代理版本:requests:2.31.0 从报错可以看出,是proxy相关的报错调整代码,设定不使用代理,将http与https对应的proxy值置空即可(尝试过proxies={},但此写法不生效)proxies={'http':'','https':''}response = requests.get('https://xxx......
  • python基础函数
    1.为什么使用函数使用函数的目的是去减少代码的冗余性,简化代码的复杂度2.如何去定义一个函数以def开头去进行相关的定义在def的后面我们就去以见明知意的方式去定义一个函数的名称在函数名称后面的括号中去添加参数值,可以是多个参数,也可以是无餐的3.函数的调用无参多......
  • 不使用 + 或 - 运算符 | 添加 2 个数字Python
    我一直在尝试编写逻辑,但测试用例失败。如何改进我的代码?代码:#Giventwointegersaandb,returnthesumofthetwointegerswithoutusingtheoperators+and-.a=-1b=1min_val=min(a,b)max_val=max(a,b)ifmin_val==max_val:pr......
  • python 中的智能 Cisco IOS 差异
    之前:hostnameFoo!interfaceGigabitEthernet1/1switchportmodetrunkswitchporttrunkallowedvlan10,20,30!interfaceGigabitEthernet1/2ipaddress192.0.2.1255.255.255.128noipproxy-arp!之后:hostnameFoo!interfaceGigabitEt......
  • 无法编译 Arduino ESP32 代码:.../python3: exec 格式错误
    昨天我使用MacOSArduinoIDE或VSCode编译Arduino草图没有任何问题。但今天什么也编译不了。我尝试在ArduinoIDE或带有Arduino扩展的VSCode中编译的任何草图都会出现此错误:fork/exec/Library/Frameworks/Python.framework/Versions/3.11/bin/python3:exec......
  • 用Python解析邮件日志
    我的任务有点困难。我有一个邮件日志,如:Oct315:30:18mail1postfix/lmtp[5369]:DB10242054:to=<XXXXX>,orig_to=<XXXXXX>,relay=ip[ip]:port,delay=1.4,delays=0.04/0/0.01/1.4,dsn=2.0.0,status=sent(2502.0.0fromMTA(smtp:[iP]:port):2502.0.0Ok:queueda......