Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

英文分词 #91

Open
jenfung opened this issue Sep 27, 2022 · 5 comments
Open

英文分词 #91

jenfung opened this issue Sep 27, 2022 · 5 comments

Comments

@jenfung
Copy link

jenfung commented Sep 27, 2022

你好,请问英文分词中,一个word会被分成多个tokens,这种情况怎么处理呢?

@lonePatient
Copy link
Owner

使用huggfaceing中的tokenizer的offset_mapping关系进行word和suword的对应关系。后期我更新下

@1390806607
Copy link

你好 请问这个有更新吗? 关于一个word会被分成多个toekns的情况

@Mxk-1
Copy link

Mxk-1 commented Jul 17, 2024

这个问题也困扰我很久,导致最后的label_ids==max_length断言失败
目前我是这样解决的
# 对输入文本进行标记化并扩展标签 tokens = [] label_ids = [] for word, label in zip(example.text_a.split(), example.labels): word_tokens = tokenizer.tokenize(word) tokens.extend(word_tokens) # 对第一个子词使用原始标签,后续子词使用 "I-" 标签 label_ids.extend( [label_map[label]] + [label_map[label.replace("B-", "I-")]] * (len(word_tokens) - 1) )

@Mxk-1
Copy link

Mxk-1 commented Jul 17, 2024

        tokens = []
        label_ids = []
        for word, label in zip(example.text_a.split(), example.labels):
            word_tokens = tokenizer.tokenize(word)
            tokens.extend(word_tokens)
            # 对第一个子词使用原始标签,后续子词使用 "I-" 标签
            label_ids.extend(
                [label_map[label]]
                + [label_map[label.replace("B-", "I-")]] * (len(word_tokens) - 1)
            )```

@Mxk-1
Copy link

Mxk-1 commented Jul 17, 2024

在代码ner_seq.py的100行左右新增可以正常运行

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants