欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺析Python與Mongodb數(shù)據(jù)庫之間的操作方法

 更新時間:2019年07月01日 09:50:32   作者:GYT0313  
這篇文章主要介紹了Python與Mongodb數(shù)據(jù)庫之間的操作,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

MongoDB 是目前最流行的 NoSQL 數(shù)據(jù)庫之一,使用的數(shù)據(jù)類型 BSON(類似 JSON)。

1. 安裝Mongodb和pymongo

Mongodb的安裝和配置

Mongodb的安裝教程請網(wǎng)上搜索, 安裝完成后,    進行以下配置過程:

1.1 創(chuàng)建目錄, 該目錄為Mongodb數(shù)據(jù)文件的存放目錄:

*注: 本人使用的不是root用戶, 所以修改目錄的擁有者. *

sudo mkdir /data
sudo chown -R python:python /data
mkdir /data/db

1.2 分別執(zhí)行命令:

第一條命令為指定端口和保存路徑, 第二條為運行mongodb數(shù)據(jù)庫.

mongod --port 27017 --dbpath /data/db
mongo --port 27017

1.3 安裝pymongo

sudo pip3 install pymongo

2. 連接數(shù)據(jù)庫、指定數(shù)據(jù)庫、指定集合、插入數(shù)據(jù):

mongodb存儲數(shù)據(jù)以鍵值形式, 因此在Python中使用字段插入數(shù)據(jù).

import pymongo
#連接mongodb
client = pymongo.MongoClient('mongodb://localhost:27017/')
#指定數(shù)據(jù)庫
db = client.test4
#指定集合
collection = db.students
#數(shù)據(jù)
student1 = {
 'id': '201801',
 'name': 'Jack',
 'age': 20,
 'gender': 'male'
}
student2 = {
 'id': '201802',
 'name': 'Tom',
 'age': 22,
 'gender': 'male'
}
student3 = {
 'id': '201803',
 'name': 'Rose',
 'age': 21,
 'gender': 'female'
}
student4 = {
 'id': '201804',
 'name': 'Mike',
 'age': 20,
 'gender': 'female'
}
student5 = {
 'id': '201805',
 'name': 'Ray',
 'age': 20,
 'gender': 'female'
}
student6 = {
 'id': '201806',
 'name': 'Alan',
 'age': 21,
 'gender': 'male'
}
#插入一條數(shù)據(jù)
result1 = collection.insert_one(student1)
print(result1)
print(result1.inserted_id)
# #插入多條數(shù)據(jù)
result2 = collection.insert_many([student2, student3, student4, student5, student6])
print(result2)
print(result2.inserted_ids)

運行結(jié)果:

insert方法:

5b3a1942971951218d41c02b
[ObjectId('5b3a1942971951218d41c02c'), ObjectId('5b3a1942971951218d41c02d')]

官方推薦:

<pymongo.results.InsertOneResult object at 0x7fa4cc363ec8>
5b3a1942971951218d41c02e
<pymongo.results.InsertManyResult object at 0x7fa4cc363f08>
[ObjectId('5b3a1942971951218d41c02f'), ObjectId('5b3a1942971951218d41c030')]

3. 查詢、計數(shù)、排序、偏移:

import pymongo
from bson.objectid import ObjectId
client = pymongo.MongoClient('mongodb://localhost:27017/')
db = client.test4
collection = db.students
#查詢一條數(shù)據(jù)
print('單條數(shù)據(jù)','='*50)
result = collection.find_one({'name': 'Jack'})
print(result)
print('多條數(shù)據(jù)','='*50)
#查詢多條數(shù)據(jù)
for res in collection.find({'age': {'$mod': [5, 0]}}):
 print(res)
#計數(shù)
print('計數(shù)','='*50)
count = collection.find({'age': {'$mod': [5, 0]}}).count()
print(count)
#排序
print('排序','='*50)
results = collection.find().sort('name', pymongo.ASCENDING) #升序, pymongo.DESCENDING為降序
print([result['name'] for result in results])
#偏移
print('偏移','='*50)
results = collection.find().sort('name', pymongo.ASCENDING).skip(2) #偏移2位,忽略前兩個數(shù)據(jù)
print([result['name'] for result in results])
results = collection.find().sort('name', pymongo.ASCENDING).skip(2).limit(2) #只輸出2個數(shù)據(jù)
print([result['name'] for result in results])
find({‘a(chǎn)ge': {'$mod': [5, 0]}}): 表示查找年齡取余5余0的值. 還有很多比較符號, 請百度.

運行結(jié)果:

單條數(shù)據(jù) ==================================================
{'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 20, 'gender': 'male'}
多條數(shù)據(jù) ==================================================
{'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 20, 'gender': 'male'}
{'_id': ObjectId('5b3a1942971951218d41c02e'), 'id': '201804', 'name': 'Mike', 'age': 20, 'gender': 'female'}
{'_id': ObjectId('5b3a1942971951218d41c02f'), 'id': '201805', 'name': 'Ray', 'age': 20, 'gender': 'female'}
計數(shù) ==================================================
3
排序 ==================================================
['Alan', 'Jack', 'Mike', 'Ray', 'Rose', 'Tom']
偏移 ==================================================
['Mike', 'Ray', 'Rose', 'Tom']
['Mike', 'Ray']

4. 更新:

4.1  不使用$set更新數(shù)據(jù):

import pymongo
from bson.objectid import ObjectId
client = pymongo.MongoClient('mongodb://localhost:27017/')
db = client.test4
collection = db.students
#修改
condition = {'name': 'Jack'}
student = collection.find_one(condition) #獲得滿足condition的數(shù)據(jù)
print('更新前: ', student)
student['age'] = 22 #修改年齡
result = collection.update(condition, student) #將修改后的student替換condition
print('更新后', collection.find_one(condition))
#更新的返回值
print(result) #ok=1代表執(zhí)行成功, nModified代表影響的條數(shù)

運行結(jié)果:

更新前: {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 20, 'gender': 'male'}
更新后 {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 22, 'gender': 'male'}
{'ok': 1, 'nModified': 1, 'n': 1, 'updatedExisting': True}

4.2  使用$set更新數(shù)據(jù):

import pymongo
from bson.objectid import ObjectId
client = pymongo.MongoClient('mongodb://localhost:27017/')
db = client.test4
collection = db.students
#使用$set更新
condition = {'name': 'Jack'}
student = collection.find_one(condition) #獲得滿足condition的數(shù)據(jù)
print('更新前: ', student)
student['age'] = 23 #修改年齡
result = collection.update(condition, {'$set': student}) #將修改后的student替換condition, $set為重點
print('更新后', collection.find_one(condition))
#更新的返回值
print(result) #ok=1代表執(zhí)行成功, nModified代表影響的條數(shù)

運行結(jié)果:

更新前: {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 22, 'gender': 'male'}
更新后 {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 23, 'gender': 'male'}
{'ok': 1, 'nModified': 1, 'n': 1, 'updatedExisting': True}

比較使用和不適用$set更新數(shù)據(jù), 發(fā)現(xiàn)此時并沒有什么區(qū)別.

下面介紹區(qū)別所在:

4.3  區(qū)別

import pymongo
from bson.objectid import ObjectId
client = pymongo.MongoClient('mongodb://localhost:27017/')
db = client.test4
collection = db.students
#使用和不使用$set更新的區(qū)別
print('使用: ')
condition = {'name': 'Jack'}
student = collection.find_one(condition) #獲得滿足condition的數(shù)據(jù)
print('更新前: ', student)
student = {
 'id': '201803',
 'name': 'Jack',
 'age': 20,
 'gender': 'female',
 'mother': "Jack's mother"
}
result = collection.update(condition, {'$set': student}) #將修改后的student替換condition
print('更新后', collection.find_one(condition))
#更新的返回值
print(result) #ok=1代表執(zhí)行成功, nModified代表影響的條數(shù)
#分割線
print()
print('='*20, '分割線', '='*20)
print()
print('不使用: ')
condition = {'name': 'Jack'}
student = collection.find_one(condition) #獲得滿足condition的數(shù)據(jù)
print('更新前: ', student)
student = {
 'id': '201803',
 'name': 'Jack',
 'age': 20,
 'gender': 'female',
 'father': "Jack's father"
}
result = collection.update(condition, student) #將修改后的student替換condition
print('更新后', collection.find_one(condition))
#更新的返回值
print(result) #ok=1代表執(zhí)行成功, nModified代表影響的條數(shù)

運行結(jié)果:

使用:

更新前: {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201801', 'name': 'Jack', 'age': 23, 'gender': 'male'}
更新后 {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201803', 'name': 'Jack', 'age': 20, 'gender': 'female', 'mother': "Jack's mother"}
{'ok': 1, 'nModified': 1, 'n': 1, 'updatedExisting': True}

==================== 分割線 ====================

不使用: 
更新前: {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201803', 'name': 'Jack', 'age': 20, 'gender': 'female', 'mother': "Jack's mother"}
更新后 {'_id': ObjectId('5b3a1942971951218d41c02b'), 'id': '201803', 'name': 'Jack', 'age': 20, 'gender': 'female', 'father': "Jack's father"}
{'ok': 1, 'nModified': 1, 'n': 1, 'updatedExisting': True}

分析上面運行結(jié)果, 可以發(fā)現(xiàn)使用$set時, 若更新數(shù)據(jù)有原數(shù)據(jù)沒有的字段, 則將該字段加到原數(shù)據(jù)上(上例為新增了mother字段), 而不會刪除任何字段. 相反, 若不使用set時, 將從原數(shù)據(jù)中刪除更新數(shù)據(jù)沒有的字段, 再加上新增字段(上例為刪除了mother字段, 新增了father字段. 也可以理解為將原數(shù)據(jù)完全替換為更新數(shù)據(jù))

4.4  update_one和update_many的區(qū)別:

import pymongo
from bson.objectid import ObjectId
client = pymongo.MongoClient('mongodb://localhost:27017/')
db = client.test4
collection = db.students
#官方推薦使用
#update_one和update_many的區(qū)別
print('update_one: ')
condition = {'age': {'$gt': 20}}
result = collection.update_one(condition, {'$inc': {'age': 1}})
print(result)
print(result.matched_count, result.modified_count)
#分割線
print()
print('='*20, '分割線', '='*20)
print()
print('update_many: ')
condition = {'age': {'$gt': 20}}
result = collection.update_many(condition, {'$inc': {'age': 1}})
print(result)
print(result.matched_count, result.modified_count)

運行結(jié)果:

update_one: 
<pymongo.results.UpdateResult object at 0x7f6cace0f9c8>
1 1
==================== 分割線 ====================
update_many: 
<pymongo.results.UpdateResult object at 0x7f6cace0fa88>
3 3
12345678910
{‘a(chǎn)ge': {'$gt': 20}}為查找年齡大于20的, {‘inc': {‘a(chǎn)ge': 1}}為將年齡+1

5. 刪除:

import pymongo
from bson.objectid import ObjectId
client = pymongo.MongoClient('mongodb://localhost:27017/')
db = client.test4
collection = db.students
#刪除
result = collection.remove({'name': 'Jack'})
print(result)
#推薦使用
result = collection.delete_one({'age': {'$gt': 20}})
print(result.deleted_count)
result = collection.delete_many({'age': {'$gt': 20}})
print(result.deleted_count)

運行結(jié)果:

{'ok': 1, 'n': 1}
1
2

6. 其他

除了上述常用的之外, 還包括find_one_and_delete()查找后刪除、find_one_and_replace()查找后替換, 有興趣可以百度深入了解.

總結(jié)

以上所述是小編給大家介紹的Python與Mongodb數(shù)據(jù)庫之間的操作方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • 利用Python編寫一個注冊機用于生成卡密

    利用Python編寫一個注冊機用于生成卡密

    這篇文章主要為大家詳細介紹了如何利用Python編寫一個注冊機用于生成卡密(兌換碼),并使用這些卡密登錄應用程序,感興趣的小伙伴可以了解下
    2023-11-11
  • Python數(shù)據(jù)分析入門之教你怎么搭建環(huán)境

    Python數(shù)據(jù)分析入門之教你怎么搭建環(huán)境

    本篇文章要有一定的Python基礎,知道列表,字符串,函數(shù)等的用法. 文中有非常詳細的代碼示例,對正在入門python數(shù)據(jù)分析的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • python聊天程序?qū)嵗a分享

    python聊天程序?qū)嵗a分享

    這篇文章主要介紹了用python寫的聊天程序,開兩個線程,即是客戶端,也是服務器,大家可以參考使用
    2013-11-11
  • python3.7將代碼打包成exe程序并添加圖標的方法

    python3.7將代碼打包成exe程序并添加圖標的方法

    這篇文章主要介紹了python3.7將代碼打包成exe程序并添加圖標的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-10-10
  • python用folium繪制地圖并設置彈窗效果

    python用folium繪制地圖并設置彈窗效果

    這篇文章主要介紹了python用folium繪制地圖并設置彈窗,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • python使用matplotlib庫生成隨機漫步圖

    python使用matplotlib庫生成隨機漫步圖

    這篇文章主要為大家詳細介紹了使用Python的matplotlib庫生成隨機漫步圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • python爬蟲入門教程--快速理解HTTP協(xié)議(一)

    python爬蟲入門教程--快速理解HTTP協(xié)議(一)

    http協(xié)議是互聯(lián)網(wǎng)里面最重要,最基礎的協(xié)議之一,我們的爬蟲需要經(jīng)常和http協(xié)議打交道。下面這篇文章主要給大家介紹了關(guān)于python爬蟲入門之快速理解HTTP協(xié)議的相關(guān)資料,文中介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-05-05
  • Python中Get()函數(shù)用法舉例介紹

    Python中Get()函數(shù)用法舉例介紹

    這篇文章主要給大家介紹了關(guān)于Python中Get()函數(shù)用法的相關(guān)資料,Python get()函數(shù)是一個非常重要的函數(shù),它可以幫助我們從字典中獲取對應鍵的值,避免了因為鍵不存在而發(fā)生錯誤的情況,需要的朋友可以參考下
    2023-10-10
  • 自適應線性神經(jīng)網(wǎng)絡Adaline的python實現(xiàn)詳解

    自適應線性神經(jīng)網(wǎng)絡Adaline的python實現(xiàn)詳解

    這篇文章主要介紹了自適應線性神經(jīng)網(wǎng)絡Adaline的python實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • 從pandas一個單元格的字符串中提取字符串方式

    從pandas一個單元格的字符串中提取字符串方式

    今天小編就為大家分享一篇從pandas一個單元格的字符串中提取字符串方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12

最新評論