pyspark编程对如下两个dataframe进行查询操作,如何提高效率?

发布于 2022-09-04 15:12:22 字数 1103 浏览 31 评论 0

1、有两个DataFrame:df1,df2都有共同的字段ACCTNO,df1中每行的ACCTNO字段唯一,需要遍历df1中的ACCTNO字段,并根据这些ACCTNO字段查询df2中对应的数据。
2、代码如下
`

def get_acctre(part,df2):
    for raw in part:
        ACCTNO = list(raw)[0]
        acct_df = df2.filter("ACCTNO ='"+ACCTNO+"'")
df1.foreachPartition(lambda part:get_acctre(part,df2)) 

`
3、根据分析,发现把df2作为get_acctre()的参数就会报如下错误

PicklingError: Could not serialize object: Py4JError: An error occurred while calling o624.__getnewargs__. Trace:
py4j.Py4JException: Method __getnewargs__([]) does not exist
    at py4j.reflection.ReflectionEngine.getMethod(ReflectionEngine.java:318)
    at py4j.reflection.ReflectionEngine.getMethod(ReflectionEngine.java:326)
    at py4j.Gateway.invoke(Gateway.java:272)
    at py4j.commands.AbstractCommand.invokeMethod(AbstractCommand.java:132)
    at py4j.commands.CallCommand.execute(CallCommand.java:79)
    at py4j.GatewayConnection.run(GatewayConnection.java:214)
    at java.lang.Thread.run(Thread.java:745)

4、由于df2不能作为参数传入函数get_acctre,如何才能高效率实现目的呢?才接触spark编程,还不熟悉相关函数,希望有大佬指点一二

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

别在捏我脸啦 2022-09-11 15:12:22

基本上是 JOIN  操作的思路吧,
df1 注册为一个table1
df2 注册为一个table2
采用SPARK SQL的方式 ,查询这两个表格

select 
    *
from 
    table1 as t1 
left join 
    table2 as t2
 on t1.key = t2.key 
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文