記錄一次從txt文件導入數據的python下的MySQL實現

来源:http://www.cnblogs.com/elijahxb/archive/2017/07/09/7141646.html
-Advertisement-
Play Games

環境: python2.7 ComsenzXP自帶MySQL 安裝python-MySQL模塊 數據格式:txt格式的賬號信息。 數據一行一條數據。 難點:有的行只有賬號,沒有密碼;有的為空行;有的行首行尾有三連引號;有的空行;有的不是賬號密碼信息。 代碼實現: ...


環境: python2.7

    ComsenzXP自帶MySQL

    安裝python-MySQL模塊

數據格式:txt格式的賬號信息。

     數據一行一條數據。

    難點:有的行只有賬號,沒有密碼;有的為空行;有的行首行尾有三連引號;有的空行;有的不是賬號密碼信息。

 

代碼實現:

 1 #!/usr/bin/env python
 2 # encoding: utf-8
 3 
 4 
 5 """
 6 @version: ??
 7 @author: elijahxb
 8 @contact: [email protected]
 9 @site: http://www.cnblogs.com/elijahxb
10 @software: PyCharm Community Edition
11 @file: main.py
12 @time: 2017/7/8 23:47
13 """
14 import MySQLdb
15 import os
16 #import re
17 
18 Conn_IP = '127.0.0.1'
19 Conn_UserName = 'root'
20 Conn_PassWord = '11111111'
21 Conn_database = 'qqdata'
22 Conn_Table = 'login'
23 Conn_Port = 3306
24 
25 importpath = u"""D:\QQ資料庫""".encode("gbk")
26 pattern = "[0-9,a-z,A-Z]{4,12}"
27 sumlist = []
28 def gett(path):
29     filedata = []
30     onedata = []
31     filelist = os.listdir(path)
32     for file in filelist:
33         print "處理文件中... ->" + file
34         with open(os.path.join(path,file),'r') as fh:
35             lines = fh.readlines()
36         for index,line in enumerate(lines):
37             print "正在處理第{0}行數據,進度{0}/{1},【{2}】".format(index,len(lines),str(float("%0.2f"%(float(index)/len(lines)))*100) + "%")
38             if len(line) < 14:
39                 continue
40             elif '"""' in line:
41                 line = line.split('"""')[1]
42             text_l = line.split(" ")
43             username = text_l[0]
44             passwd = text_l[1].split("\n")[0]
45             if len(username) < 4 or len(passwd) < 4:
46                 continue
47             onedata.append(username)
48             onedata.append("'" + passwd + "'")
49             filedata.append(tuple(onedata))
50             onedata = []
51             filedata = list(set(filedata))#清除一個文件裡面的所有重覆項
52         sumlist.append(tuple(filedata))
53     return sumlist
54 
55 
56 
57 conn = MySQLdb.Connect(host = Conn_IP,
58                        user = Conn_UserName,
59                        passwd = Conn_PassWord,
60                        db = Conn_database,
61                        port = Conn_Port
62                        )
63 cur = conn.cursor()
64 cur.execute("use qqdata")
65 cur.execute("truncate table login")
66 sqlcmd = "insert into login (QQ,PWD) values(%s,%s)"
67 t = gett(importpath)
68 for singlefiledata in t:
69     cur.executemany(sqlcmd,singlefiledata)
70 cur.close()
71 conn.close()

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • str類型python並沒有reverse函數。 然而,通過反向步進切片,我們可以高效地反轉一串字元串。 僅支持英文字元。 例: ...
  • SSM框架搭建(一) JDK和MAVEN環境搭建 SSM框架搭建(二) 創建MAVEN項目 SSM框架搭建(三) 資料庫創建和MyBatis生成器自動生成實體類、DAO介面和Mapping映射文件 SSM框架搭建(四) springmvc和mybatis的配置 JDK配置 CLASSPATH .;% ...
  • 6.高階特性 6.1迭代 如果給定一個list或tuple,我們可以通過for迴圈來遍歷這個list或tuple,這種遍歷我們稱為迭代(Iteration)。在Python中,迭代是通過for ... in來完成的。 因為dict的存儲不是按照list的方式順序排列,所以,迭代出的結果順序很可能不一 ...
  • 題目描述 歐幾里德的兩個後代Stan和Ollie正在玩一種數字游戲,這個游戲是他們的祖先歐幾里德發明的。給定兩個正整數M和N,從Stan開始,從其中較大的一個數,減去較小的數的正整數倍,當然,得到的數不能小於0。然後是Ollie,對剛纔得到的數,和M,N中較小的那個數,再進行同樣的操作……直到一個人 ...
  • 題目描述 在幻想鄉,上白澤慧音是以知識淵博聞名的老師。春雪異變導致人間之里的很多道路都被大雪堵塞,使有的學生不能順利地到達慧音所在的村莊。因此慧音決定換一個能夠聚集最多人數的村莊作為新的教學地點。人間之里由N個村莊(編號為1..N)和M條道路組成,道路分為兩種一種為單向通行的,一種為雙向通行的,分別 ...
  • 一 概述 1.什麼是重載? 利用形參區分同一個類中多個同名方法的機制叫做重載。 2.什麼是重寫? 子類繼承父類,重寫父類方法的過程叫做重寫。 二 對比 1.發生範圍 重寫發生在父類與子類之間,涉及兩個類,重載發生在同一個類內部。 2.約束 重寫 重載 重載正是根據方法的形參來區分同名的方法,所以同名 ...
  • Java中的集合框架(中) 由於Java中的集合框架的內容比較多,在這裡分為三個部分介紹Java的集合框架,內容是從淺到深,如果已經有java基礎的小伙伴可以直接跳到<淺入深出之Java集合框架(下)>。 目 錄 淺入深出之Java集合框架(上) 淺入深出之Java集合框架(中) 淺入深出之Java ...
  • Descriptions: Given a sorted array, remove the duplicates in place such that each element appear only once and return the new length. Do not allocate ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...