这应该不需要解释。但有人可能会描述子串的pos参数背后的逻辑,因为我无法理解这一点(使用Spark 2.1):
scala> val df = Seq("abcdef").toDS()
df: org.apache.spark.sql.Dataset[String] = [value: string]
scala> df.show
+------+
| value|
+------+
|abcdef|
+------+
scala> df.selectExpr("substring(value, 0, 2)", "substring(value, 1, 2)", "substring(value, 2,2)", "substring(value, 3,2)").show
+----------------------+----------------------+----------------------+----------------------+
|substring(value, 0, 2)|substring(value, 1, 2)|substring(value, 2, 2)|substring(value, 3, 2)|
+----------------------+----------------------+----------------------+----------------------+
| ab| ab| bc| cd|
+----------------------+----------------------+----------------------+----------------------+
答案 0 :(得分:8)
第一个值来自它应该从哪个索引开始(从1开始而不是从0开始) 第二个值是从索引中取出的字符数