2 使用自己的数据训练一个简单的二分类模型

1 下载数据

1null手把手带你实战 Huggingface Transformers 课程视频同步更新在B站与YouTube - transformers-code/01-Getting Started/04-model/ChnSentiCorp_htl_all.csv at master · zyds/transformers-codehttps://github.com/zyds/transformers-code/blob/master/01-Getting%20Started/04-model/ChnSentiCorp_htl_all.csv手把手带你实战 Huggingface Transformers 课程视频同步更新在B站与YouTube - transformers-code/01-Getting Started/04-model/ChnSentiCorp_htl_all.csv at master · zyds/transformers-codehttps://github.com/zyds/transformers-code/blob/master/01-Getting%20Started/04-model/ChnSentiCorp_htl_all.csv巧妇难为无米之炊,先准备数据吧!

1.1 简单数据分析:

2 上代码,上模型

1 整理数据。 2 加载预训练模型。 3 微调。

复制代码
from transformers import AutoTokenizer, AutoModelForSequenceClassification
import pandas as pd
data = pd.read_csv("./data/ChnSentiCorp_htl_all.csv")
data = data.dropna()
# 画图
data.groupby('label').count().plot(kind='bar')



# 变化成模型能够读懂的格式
from torch.utils.data import Dataset

class MyDataset(Dataset):

    def __init__(self) -> None:
        super().__init__()
        self.data = pd.read_csv("./data/ChnSentiCorp_htl_all.csv")
        self.data = self.data.dropna()

    def __getitem__(self, index):
        return self.data.iloc[index]["review"], self.data.iloc[index]["label"]
    
    def __len__(self):
        return len(self.data)
# 划分数据集
from torch.utils.data import random_split
dataset = MyDataset()

trainset, validset = random_split(dataset, lengths=[0.9, 0.1])
len(trainset), len(validset)


import torch

tokenizer = AutoTokenizer.from_pretrained("./dianping")

# 前面提到了 需要对数据进行处理称模型能够接受的格式: input_ids, token_type_ids,attention_mask
def collate_func(batch):
    texts, labels = [], []
    for item in batch:
        texts.append(item[0])
        labels.append(item[1])
    inputs = tokenizer(texts, max_length=128, padding="max_length", truncation=True, return_tensors="pt")
    inputs["labels"] = torch.tensor(labels)
    return inputs
from torch.utils.data import DataLoader

trainloader = DataLoader(trainset, batch_size=32, shuffle=True, collate_fn=collate_func)
validloader = DataLoader(validset, batch_size=64, shuffle=False, collate_fn=collate_func)



# 加载预训练模型,然后优化
from torch.optim import Adam
model = AutoModelForSequenceClassification.from_pretrained("./dianping")

if torch.cuda.is_available():
    model = model.cuda()
# 两个参数, 1 模型参数, 2 学习速率
optimizer = Adam(model.parameters(), lr=2e-5)
def evaluate():
    model.eval()
    acc_num = 0
    with torch.inference_mode():
        for batch in validloader:
            if torch.cuda.is_available():
                batch = {k: v.cuda() for k, v in batch.items()}
            output = model(**batch)
            pred = torch.argmax(output.logits, dim=-1)
            acc_num += (pred.long() == batch["labels"].long()).float().sum()
    return acc_num / len(validset)

def train(epoch=3, log_step=100):
    global_step = 0
    for ep in range(epoch):
        # 开启训练模式
        model.train()
        for batch in trainloader:
            # 是否使用显卡
            if torch.cuda.is_available():
                batch = {k: v.cuda() for k, v in batch.items()}
            # 梯度归零
            optimizer.zero_grad()
            # 计算损失
            output = model(**batch)
            # 反向求导
            output.loss.backward()
            # 迭代
            optimizer.step()
            if global_step % log_step == 0:
                print(f"ep: {ep}, global_step: {global_step}, loss: {output.loss.item()}")
            global_step += 1
        acc = evaluate()
        print(f"ep: {ep}, acc: {acc}")

train()
sen = "真的不错,推荐你来来试试这个过程!"
id2_label = {0: "差评!", 1: "好评!"}
model.eval()
with torch.inference_mode():
    inputs = tokenizer(sen, return_tensors="pt")
    inputs = {k: v.cuda() for k, v in inputs.items()}
    logits = model(**inputs).logits
    pred = torch.argmax(logits, dim=-1)
    print(f"输入:{sen}\n模型预测结果:{id2_label.get(pred.item())}")
from transformers import pipeline

model.config.id2label = id2_label
pipe = pipeline("text-classification", model=model, tokenizer=tokenizer, device=0)
复制代码
输出:
ep: 0, global_step: 0, loss: 0.3093985319137573
ep: 0, global_step: 100, loss: 0.15114116668701172
ep: 0, global_step: 200, loss: 0.18284356594085693
ep: 0, acc: 0.9123711585998535
ep: 1, global_step: 300, loss: 0.06553637981414795
ep: 1, global_step: 400, loss: 0.12580494582653046
ep: 1, acc: 0.907216489315033
ep: 2, global_step: 500, loss: 0.1393854171037674
ep: 2, global_step: 600, loss: 0.024754131212830544
ep: 2, acc: 0.907216489315033

输入:真的不错,推荐你来来试试这个过程!
模型预测结果:好评!

cpu很慢.....

相关推荐
科技小花1 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
zhuiyisuifeng3 小时前
2026前瞻:GPTimage2镜像官网或将颠覆视觉创作
人工智能·gpt
徐健峰3 小时前
GPT-image-2 热门玩法实战(一):AI 看手相 — 一张手掌照片生成专业手相分析图
人工智能·gpt
weixin_370976353 小时前
AI的终极赛跑:进入AGI,还是泡沫破灭?
大数据·人工智能·agi
Slow菜鸟3 小时前
AI学习篇(五) | awesome-design-md 使用说明
人工智能·学习
冬奇Lab3 小时前
RAG 系列(五):Embedding 模型——语义理解的核心
人工智能·llm·aigc
深小乐3 小时前
AI 周刊【2026.04.27-05.03】:Anthropic 9000亿美元估值、英伟达死磕智能体、中央重磅定调AI
人工智能
码点滴3 小时前
什么时候用 DeepSeek V4,而不是 GPT-5/Claude/Gemini?
人工智能·gpt·架构·大模型·deepseek
狐狐生风4 小时前
LangChain 向量存储:Chroma、FAISS
人工智能·python·学习·langchain·faiss·agentai
波动几何4 小时前
CDA架构代码工坊技能cda-code-lab
人工智能