啊哈哈哈哈哈啊哈哈 2023-05-15 20:21 采纳率: 66.7%
浏览 11
已结题

Scala相关的rdd编程问题map用法


scala> val res=data.map(lambda x:x.split(",")).map(lambda x:x[0])
<console>:1: error: ')' expected but '(' found.
val res=data.map(lambda x:x.split(",")).map(lambda x:x[0])
                           ^
<console>:1: error: ';' expected but ')' found.
val res=data.map(lambda x:x.split(",")).map(lambda x:x[0])
                                                            ^

感觉哪里都没出错啊友友们,怎么回事啊

  • 写回答

1条回答 默认 最新

  • Leodong. 2023-05-15 20:54
    关注

    该回答通过自己思路及引用到GPTᴼᴾᴱᴺᴬᴵ搜索,得到内容具体如下:
    在 Scala 中,map 函数是对集合中的每个元素应用指定的函数,并返回一个新的集合,因此你的代码中使用 map 函数对数据进行处理是没有问题的。

    但是,错误信息显示出现了语法错误,提示 ')' expected but '(' found.';' expected but ')' found.。这种情况通常是由于 Scala 解释器无法正确解析代码中的语法,导致出现了语法错误。

    根据你提供的代码,可能是由于 lambda 关键字不被 Scala 解释器所支持导致的。在 Scala 中,我们可以使用匿名函数或者函数字面量来代替 lambda 表达式。

    以下是使用匿名函数和函数字面量的示例代码:

    // 使用匿名函数
    val res = data.map(x => x.split(",")).map(x => x(0))
    
    // 使用函数字面量
    val res = data.map { x =>
      val arr = x.split(",")
      arr(0)
    }
    

    在这个示例代码中,我们使用匿名函数 x => x.split(",")x => x(0),以及函数字面量 { x => ... } 来代替 lambda 表达式,从而避免了语法错误的问题。

    需要注意的是,在 Scala 中,函数字面量的参数只有一个时,可以使用 (){} 将参数包裹起来。如果参数有多个,则必须使用 () 将参数列表包裹起来。

    如果你仍然无法解决问题,可以尝试将代码分成多行来书写,或者检查代码中是否存在其他语法错误。


    如果以上回答对您有所帮助,点击一下采纳该答案~谢谢

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 5月24日
  • 已采纳回答 5月16日
  • 创建了问题 5月15日

悬赏问题

  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音
  • ¥30 Pytorch深度学习服务器跑不通问题解决?
  • ¥15 部分客户订单定位有误的问题
  • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
  • ¥15 Bug traq 数据包 大概什么价
  • ¥15 在anaconda上pytorch和paddle paddle下载报错
  • ¥25 自动填写QQ腾讯文档收集表