- 前景
- 开发环境
- Go 基础
- 流程控制
- 函数
- 方法
- 面向对象
- 网络编程
- 并发编程
- 数据操作
- 常用标准库
- beego 框架
- gin 框架
- 微服务
- 插件库
- 项目
- 开源仓库
- go 学习线路图
- 音频和音乐
- 身份验证和 OAuth
- 机器人相关
- 标准 CLI
- 构建用户界面库
- 配置
- 持续集成
- CSS 预处理器
- 数据结构
- 数据库
- 数据库驱动
- 日期和时间
- 分布式系统
- 电子邮件
- 嵌入式脚本语言
- 错误处理
- 文件
- 金融
- Forms
- 功能性
- 游戏开发
- 生成与泛型
- 地理位置
- 编译器
- Goroutines
- 图形界面
- 图片
- 物联网
- 工作计划
- JSON格式
- Logging
- 机器学习
- 实现消息传递
- 微软办公软件
- 依赖注入
- 项目布局
- Strings
- 其他
- 自然语言处理
- 网络
- HTTP 客户端
- OpenGL
- ORM
- 包管理
- 性能
- 查询语言
- 资源嵌入
- 科学与数据分析
- 安全
- 序列化
- 服务器应用
- 流处理
- 模板引擎
- 测试
- 文字处理
- 第三方 API
- 实用工具
- UUID
- 验证方式
- 版本控制
- 视频
- Web 框架
- 中间件
- 路由器
- 视窗
- XML 格式
- 代码分析
- 编辑器插件
- 硬件
- go 生成工具
- go 工具
- DevOps 工具
- 其他
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
省份划分
根据身份证号的前2位把数据划分到不同的省份文件里面
package main
import (
"bufio"
"fmt"
"io"
"os"
"strings"
"sync"
)
// 按照34个省划分数据
// 1.创建34个省份,创建34个数据管道
// 2.读优质数据,写入对应省份管道
// 3.把省份管道写道对应文件,开34个协程
// 抽象出一个省份对象
type Province struct {
// Id 身份证前2位
Id string
// 省份名
Name string
// 该省对应的文件,例如 北京.txt
File *os.File
// 本省文件的数据管道
chanData chan string
}
// 声明等待组
var wg sync.WaitGroup
func main() {
// 声明个map,存放所有省市的
pMap := make(map[string]*Province)
ps := []string{"北京市11", "天津市12", "河北省13",
"山西省14", "内蒙古自治区15", "辽宁省21", "吉林省22",
"黑龙江省23", "上海市31", "江苏省32", "浙江省33", "安徽省34",
"福建省35", "江西省36", "山东省37", "河南省41", "湖北省42",
"湖南省43", "广东省44", "广西壮族自治区45", "海南省46",
"重庆市50", "四川省51", "贵州省52", "云南省53", "西藏自治区54",
"陕西省61", "甘肃省62", "青海省63", "宁夏回族自治区64", "新疆维吾尔自治区65",
"香港特别行政区81", "澳门特别行政区82", "台湾省83"}
// 遍历所有省市,创建实例,省份管道创建
for _, p := range ps {
name := p[:len(p)-2]
id := p[len(p)-2:]
// 创建对象
province := Province{Id: id, Name: name}
// 添加进map
pMap[id] = &province
// 为当前省份开一个文件
file, _ := os.OpenFile("./"+province.Name+".txt", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
province.File = file
defer file.Close()
// 创建当前省份管道
province.chanData = make(chan string, 1024)
fmt.Println(name, "管道已创建")
}
// 遍历34个省份,开34个对应文件写数据
for _, province := range pMap {
wg.Add(1)
// 写入数据,这里是map中的地址
go writeFile(province)
}
// 读优质文件,写入对应的省份管道
file, _ := os.Open("./kaifang_good.txt")
defer file.Close()
// 缓冲读取
reader := bufio.NewReader(file)
// 逐行读
for {
lineBytes, _, err := reader.ReadLine()
if err == io.EOF {
for _, province := range pMap {
close(province.chanData)
fmt.Println(province.Name, "管道已经关闭")
}
break
}
// 转str,转utf
lineStr := string(lineBytes)
// 逗号切分
fieldsSlice := strings.Split(lineStr, ",")
id := fieldsSlice[1][0:2]
// 对号入座,写入对应管道
if provice, ok := pMap[id]; ok {
provice.chanData <- (lineStr + "\n")
} else {
fmt.Println("未知的省", id)
}
}
wg.Wait()
}
// 向文件写数据
func writeFile(province *Province) {
for lineStr := range province.chanData {
province.File.WriteString(lineStr)
fmt.Print(province.Name, "写入", lineStr)
}
wg.Done()
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论