Когда я использую RegexTokenizer from pyspark.ml.feature для токенизации столбца предложений в моем фрейме данных, чтобы найти все символы слов, я получаю противоположное тому, что я получил бы, когда пакет python re используется для того же предложения. Вот пример кода:
from pyspark.sql import SparkSession
from pyspark.ml.feature import RegexTokenizer
spark = SparkSession.builder \
.master("local") \
.appName("Word list") \
.getOrCreate()
df = spark.createDataFrame(data = [["Hi there, I have a question about RegexTokenizer, Could you
please help me..."]], schema = ["Sentence"])
regexTokenizer = RegexTokenizer(inputCol="Sentence", outputCol="letters", pattern="\\w")
df = regexTokenizer.transform(df)
df.first()['letters']
Это дает следующий результат:
[' ', ', ', ' ', ' ', ' ', ' ', ' ', ', ', ' ', ' ', ' ', ' ', '...']
С другой стороны, если я использую модуль re в том же предложении и используйте тот же шаблон для сопоставления букв, используя этот код здесь:
import re
sentence = "Hi there, I have a question about RegexTokenizer, could you
please help me..."
letters_list = re.findall("\\w", sentence)
print(letters_list)
Я получаю желаемый результат в соответствии с шаблоном регулярного выражения как:
['H', 'i', 't', 'h', 'e', 'r', 'e', 'I', 'h', 'a', 'v', 'e', 'a',
'q', 'u', 'e', 's', 't', 'i', 'o', 'n', 'a', 'b', 'o', 'u', 't',
'R', 'e', 'g', 'e', 'x', 'T', 'o', 'k', 'e', 'n', 'i', 'z', 'e',
'r', 'c', 'o', 'u', 'l', 'd', 'y', 'o', 'u', 'p', 'l', 'e', 'a',
's', 'e', 'h', 'e', 'l', 'p', 'm', 'e']
Я также обнаружил, что Мне нужно использовать \ W вместо \ w в pySpark, чтобы решить эту проблему. Почему такая разница? Или я неправильно понял использование аргумента pattern в RegexTokenizer ?