当前位置: 首页 > wzjs >正文

浙江省工程建设管理质量协会网站个人网站建站流程

浙江省工程建设管理质量协会网站,个人网站建站流程,网站开发相关书籍资料,小说网站模板Ecdict 下载词典文件stardict.7z,解压,stardict.csv是一个CSV格式的文本文件,文件的第一行是表头,除第一行外,其他每行文本是一个单词的相关信息,用逗号分隔的就是各个列的值。英汉词典ECDICT中导入单词到…

Ecdict

  1. 下载词典文件stardict.7z,解压,stardict.csv是一个CSV格式的文本文件,文件的第一行是表头,除第一行外,其他每行文本是一个单词的相关信息,用逗号分隔的就是各个列的值。
  2. 英汉词典ECDICT中导入单词到数据库。
  3. T_WordItems:Id(主键)、Word(单词)、Phonetic(音标)、Definition(英文解释),Translation(中文翻译)

https://github.com/skywind3000/ECDICTicon-default.png?t=O83Ahttps://github.com/skywind3000/ECDICT

实现

  1. ImportExecutor中注入IHubContext<ImportDictHub>等服务。
  2. 暂时用字符串Split解析CSV,或者用更专业的库。
  3. 用SqlBulkCopy 进行分批快速导入:

Program.cs

builder.Services.AddSignalR();string[] urls = new[] { "http://localhost:5173" };
builder.Services.AddCors(options =>options.AddDefaultPolicy(builder => builder.WithOrigins(urls).AllowAnyMethod().AllowAnyHeader().AllowCredentials()));builder.Services.AddScoped<ImportExecutor>();app.MapHub<ImportHub>("/ImportHub");

ImportExecutor.cs

public class ImportExecutor
{private readonly IHubContext<ImportHub> hubContext;public ImportExecutor(IHubContext<ImportHub> hubContext){this.hubContext = hubContext;}public async Task ExecuteAsync(string connectionId){string[] lines = await File.ReadAllLinesAsync(@"F:\Demo\stardict\stardict.csv");int totalCount = lines.Length - 1;string connStr = "Data Source=.;Initial Catalog=demo;Integrated Security=SSPI;TrustServerCertificate=true";SqlBulkCopy bulkCopy = new SqlBulkCopy(connStr);bulkCopy.DestinationTableName = "T_WordItems";bulkCopy.ColumnMappings.Add("Word", "Word");bulkCopy.ColumnMappings.Add("Phonetic", "Phonetic");bulkCopy.ColumnMappings.Add("Definition", "Definition");bulkCopy.ColumnMappings.Add("Translation", "Translation");int counter = 0;using DataTable dataTable = new DataTable();dataTable.Columns.Add("Word");dataTable.Columns.Add("Phonetic");dataTable.Columns.Add("Definition");dataTable.Columns.Add("Translation");foreach (var item in lines){string[] str = item.Split(',');string word = str[0];string? phonetic = str[1];string? definition = str[2];string? translation = str[3];DataRow row = dataTable.NewRow();row["Word"] = word;row["Phonetic"] = phonetic;row["Definition"] = definition;row["Translation"] = translation;dataTable.Rows.Add(row);counter++;Console.WriteLine($"已加载{counter}");if (dataTable.Rows.Count == 100){await bulkCopy.WriteToServerAsync(dataTable);dataTable.Clear();}await hubContext.Clients.Client(connectionId).SendAsync("ImportProgress",totalCount,counter);}await bulkCopy.WriteToServerAsync(dataTable);await hubContext.Clients.Client(connectionId).SendAsync("ImportProgress", totalCount, counter);}
}

ImportEcdict.cs

public class ImportHub : Hub
{private readonly ImportExecutor importExecutor;public ImportHub(ImportExecutor importExecutor){this.importExecutor = importExecutor;}public Task ImportEcdict(){_ = importExecutor.ExecuteAsync(this.Context.ConnectionId);return Task.CompletedTask;}
}

Vue

<template><div><input type="button" value="导入" v-on:click="importEcdict"><progress :value="state.importedCount" :max="state.totalCount"></progress><span>{{ state.importedCount }},{{ state.totalCount }}{{ ((state.importedCount / state.totalCount)*100).toFixed(2)}}%</span></div>
</template><script>
import { reactive, onMounted } from 'vue';
import * as signalR from '@microsoft/signalr';
import axios from 'axios';let connection;
export default {name: 'Login',setup() {//创建响应式对象const state = reactive({ importedCount: 0, totalCount: 0 });onMounted(async function () {startConn()})//SignalR连接const startConn = async function () {const transport = signalR.HttpTransportType.WebSockets;const options = { skipNegotiation: true, transport: transport };connection = new signalR.HubConnectionBuilder().withUrl('https://localhost:7222/ImportHub', options).withAutomaticReconnect().build();try {await connection.start();} catch (err) {alert(err);return;}//接收消息connection.on('ImportProgress', (totalCount, counter) => {//监听服务器端发送过来的信息state.importedCount = counter;state.totalCount = totalCount});}//导入const importEcdict = async function (e) {await connection.invoke("ImportEcdict");// alert("启动导入")}//返回响应式对象和方法return { state, importEcdict };}
}
</script>

http://www.dtcms.com/wzjs/463381.html

相关文章:

  • 58同城济南网站建设营业推广的概念
  • 织梦网站搬家工具seoshanghai net
  • 商城手机网站设计百度推广400电话
  • 嘉兴哪里可以做淘宝网站五种关键词优化工具
  • 网站开发自学要多久bt磁力搜索引擎在线
  • 大家做公司网站 都是在哪里做的网站首页关键词如何优化
  • 网页链接怎么转换成pdfseo排名关键词点击
  • c 做网站教程百度小说风云榜总榜
  • 当今做那些网站能致富长沙seo公司
  • 湖北省建设工程质量安全监督网站管理方面的培训课程
  • 做的网站怎样适配手机屏幕抖音seo教程
  • 上海做壁画的网站公司企业网站制作
  • 网购软件seo排名优化工具推荐
  • 郑州汉狮哪家做网站好百度热搜seo
  • 做网站用什么数据库百度小说排名
  • 做电商看的网站有哪些手机免费建站系统
  • unity3d做网站重庆seo排名优化费用
  • 西安模板网站建设套餐seo服务公司
  • 网站建设的经费广告优化师
  • 买模板做网站百度搜索资源平台
  • 网站流量多少百度搜索引擎优化的方法
  • 网站淘宝客一般怎么做域名seo站长工具
  • 做app还是做网站高端网站建设
  • 零陵区住房和城乡建设局网站免费学生网页制作成品代码
  • wordpress 测评插件搜狗seo软件
  • 房屋设计装修软件免费appseo日常优化内容是什么
  • 菲律宾bc网站总代理怎么做最新域名解析
  • 菏泽财富中心网站建设创建网站的软件
  • 保定市建设局质监站网站短网址
  • 宝宝投票网站怎么做的网络黄页推广大全