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

搜狐网站开发做网站的去那里接单

搜狐网站开发,做网站的去那里接单,自己建设网站需要审核吗,织梦转wordpress插件下载地址前段时间帮同事处理了一个把 CSV 数据导入到 MySQL 的需求。两个很大的 CSV 文件#xff0c; 分别有 3GB、2100 万条记录和 7GB、3500 万条记录。对于这个量级的数据#xff0c;用简单的单进程#xff0f;单线程导入 会耗时很久#xff0c;最终用了多进程的方式来实现。具体…前段时间帮同事处理了一个把 CSV 数据导入到 MySQL 的需求。两个很大的 CSV 文件 分别有 3GB、2100 万条记录和 7GB、3500 万条记录。对于这个量级的数据用简单的单进程单线程导入 会耗时很久最终用了多进程的方式来实现。具体过程不赘述记录一下几个要点批量插入而不是逐条插入为了加快插入速度先不要建索引生产者和消费者模型主进程读文件多个 worker 进程执行插入注意控制 worker 的数量避免对 MySQL 造成太大的压力注意处理脏数据导致的异常原始数据是 GBK 编码所以还要注意转换成 UTF-8用 click 封装命令行工具具体的代码实现如下#!/usr/bin/env python# -*- coding: utf-8 -*-import codecsimport csvimport loggingimport multiprocessingimport osimport warningsimport clickimport MySQLdbimport sqlalchemywarnings.filterwarnings(ignore, categoryMySQLdb.Warning)# 批量插入的记录数量BATCH 5000DB_URI mysql://rootlocalhost:3306/example?charsetutf8engine sqlalchemy.create_engine(DB_URI)def get_table_cols(table):sql SELECT * FROM {table} LIMIT 0.format(tabletable)res engine.execute(sql)return res.keys()def insert_many(table, cols, rows, cursor):sql INSERT INTO {table} ({cols}) VALUES ({marks}).format(tabletable,cols, .join(cols),marks, .join([%s] * len(cols)))cursor.execute(sql, *rows)logging.info(process %s inserted %s rows into table %s, os.getpid(), len(rows), table)def insert_worker(table, cols, queue):rows []# 每个子进程创建自己的 engine 对象cursor sqlalchemy.create_engine(DB_URI)while True:row queue.get()if row is None:if rows:insert_many(table, cols, rows, cursor)breakrows.append(row)if len(rows) BATCH:insert_many(table, cols, rows, cursor)rows []def insert_parallel(table, reader, w10):cols get_table_cols(table)# 数据队列主进程读文件并往里写数据worker 进程从队列读数据# 注意一下控制队列的大小避免消费太慢导致堆积太多数据占用过多内存queue multiprocessing.Queue(maxsizew*BATCH*2)workers []for i in range(w):p multiprocessing.Process(targetinsert_worker, args(table, cols, queue))p.start()workers.append(p)logging.info(starting # %s worker process, pid: %s..., i 1, p.pid)dirty_data_file ./{}_dirty_rows.csv.format(table)xf open(dirty_data_file, w)writer csv.writer(xf, delimiterreader.dialect.delimiter)for line in reader:# 记录并跳过脏数据: 键值数量不一致if len(line) ! len(cols):writer.writerow(line)continue# 把 None 值替换为 NULLclean_line [None if x NULL else x for x in line]# 往队列里写数据queue.put(tuple(clean_line))if reader.line_num % 500000 0:logging.info(put %s tasks into queue., reader.line_num)xf.close()# 给每个 worker 发送任务结束的信号logging.info(send close signal to worker processes)for i in range(w):queue.put(None)for p in workers:p.join()def convert_file_to_utf8(f, rv_fileNone):if not rv_file:name, ext os.path.splitext(f)if isinstance(name, unicode):name name.encode(utf8)rv_file {}_utf8{}.format(name, ext)logging.info(start to process file %s, f)with open(f) as infd:with open(rv_file, w) as outfd:lines []loop 0chunck 200000first_line infd.readline().strip(codecs.BOM_UTF8).strip() \nlines.append(first_line)for line in infd:clean_line line.decode(gb18030).encode(utf8)clean_line clean_line.rstrip() \nlines.append(clean_line)if len(lines) chunck:outfd.writelines(lines)lines []loop 1logging.info(processed %s lines., loop * chunck)outfd.writelines(lines)logging.info(processed %s lines., loop * chunck len(lines))click.group()def cli():logging.basicConfig(levellogging.INFO,format%(asctime)s - %(levelname)s - %(name)s - %(message)s)cli.command(gbk_to_utf8)click.argument(f)def convert_gbk_to_utf8(f):convert_file_to_utf8(f)cli.command(load)click.option(-t, --table, requiredTrue, help表名)click.option(-i, --filename, requiredTrue, help输入文件)click.option(-w, --workers, default10, helpworker 数量默认 10)def load_fac_day_pro_nos_sal_table(table, filename, workers):with open(filename) as fd:fd.readline() # skip headerreader csv.reader(fd)insert_parallel(table, reader, wworkers)if __name__ __main__:cli()以上就是本文给大家分享的全部没人了希望大家能够喜欢希望与广大网友互动点此进行留言吧
http://www.zqtcl.cn/news/53392/

相关文章:

  • 如何做国外的电商网站网站添加cms
  • 西部数码网站管理助手 伪静态湖北高端网站建设价格
  • 公司建设网站的优势西安大雁塔附近酒店推荐
  • 网站推广软件工具学校怎么创建网站
  • 电子商务网站建设ppt模板下载怎么修改网站首页logo
  • 具有价值的响应式网站个人网站建设完整教程
  • 国土网站建设自查报告户外做爰网站
  • 台州市建设规划局网站班子成员营销推广技巧
  • 益阳网站建设公司昆明好的网站制作
  • 建筑师网站有哪些完整的网站开发流程
  • 张店做网站自助建站系统模板
  • 荥阳做公司网站的公司互联网设计师工资一般多少
  • wordpress文章中添加音乐广州seo网站推广费用
  • 音乐网站建设目标手机上如何建立wordpress
  • 网站阴影wordpress转换为html5
  • 网站界面设计尺寸网站域名登陆地址
  • 企业网站备案多少钱全球邮企业邮箱登录入口
  • 文案素材网站php网站挂马
  • 网站建设开发服务费怎么做账wordpress+登录页加密
  • 做外贸如何分析客户网站婚纱照网站
  • 江津集团网站建设在线制作网站公章
  • 高考写作网站泰州网站制作专业
  • 肃州区住房和城乡建设局网站企业滴滴app下载
  • 南屏网站建设苏州刚刚发生的大事
  • 网站开发 数据库自助网站建设
  • 做网站销售说辞长沙广告传媒有限公司
  • 郑州网站建设外包互联网营销的概念
  • 商城网站后台模板和平网站建设
  • 网站建设合优做校园二手交易网站的目的
  • 网站建设骗子公司崇州市微信端网站建