簡體   English   中英

使用 Pymongo 刪除字段

[英]Deleting Field using Pymongo

我沒有足夠的聲譽發表評論,因此我不得不再次提出這個問題。

我嘗試了不同的方法來刪除我在這里提到的動態更改的日期列,但對我沒有任何作用: 如何從 MongoDB 文檔中完全刪除字段?

Environment_Details - 操作系統:Windows10,pymongo:3.10.1,MongoDB Compass App:4.4,python:3.6

我正在嘗試刪除“2020/08/24”列(在我的情況下,此日期將是動態的)。 我的數據如下所示:

    [{
  "_id": {
    "$oid": "5f4e4dda1031d5b55a3adc70"
  },
  "Site": "ABCD",
  "2020/08/24": "1",
  "2020/08/25": "1.0"
},{
  "_id": {
    "$oid": "5f4e4dda1031d5b55a3adc71"
  },
  "Site": "EFGH",
  "2020/08/24": "1",
  "2020/08/25": "0.0"
}]

不會向我拋出任何錯誤但也不會刪除列/字段“2020/08/24”的命令:

col_name = "2020/08/24"
db.collection.update_many({}, {"$unset": {f"{col_name}":1}})
db.collection.update({}, {"$unset": {f"{col_name}":1}}, False, True)
db.collection.update_many({}, query =[{ '$unset': [col_name] }])

嘗試將 multi:True 與更新選項一起使用時,我總是遇到錯誤。

我使用的確切代碼是:

    import pymongo
def connect_mongo(host, port, db):
    conn = pymongo.MongoClient(host, port)
    return conn[db]


def close_mongo(host, port):
    client = pymongo.MongoClient(host, port)
    client.close()


def delete_mongo_field(db, collection, col_name, host, port):
    """Delete column/field from a collection"""
    db = connect_mongo(host, port, db)
    db.collection.update_many({}, {"$unset": {f"{col_name}":1}})
    #db.collection.update_many({}, {'$unset': {f'{col_name}':''}})
    close_mongo(host,port)      

        
col_to_delete = "2020/08/30"
delete_mongo_field(mydb, mycollection, col_to_delete, 'localhost', 27017)

另外,您可能需要考慮更改數據模型以將日期存儲為值而不是鍵,並考慮將它們存儲為本地日期對象,例如

import datetime
import pytz

db.testcollection.insert_many([
    {
        "Site": "ABCD",
        "Dates":  [
            {
                "Date": datetime.datetime(2020, 8, 24, 0, 0, tzinfo=pytz.UTC),
                "Value": "1"
            },
            {
                "Date": datetime.datetime(2020, 8, 25, 0, 0, tzinfo=pytz.UTC),
                "Value": "1.0"
            }]
    },
    {
        "Site": "EFGH",
        "Dates": [
            {
                "Date": datetime.datetime(2020, 8, 24, 0, 0, tzinfo=pytz.UTC),
                "Value": "1"
            },
            {
                "Date": datetime.datetime(2020, 8, 25, 0, 0, tzinfo=pytz.UTC),
                "Value": "0.1"
            }]
    }])

但是回到你的問題......第一個例子對我來說很好。 你可以試試下面的示例代碼,看看你是否得到不同的結果:

from pymongo import MongoClient
import pprint

db = MongoClient()['testdatabase']

db.testcollection.insert_many([{
    "Site": "ABCD",
    "2020/08/24": "1",
    "2020/08/25": "1.0"
}, {
    "Site": "EFGH",
    "2020/08/24": "1",
    "2020/08/25": "0.0"
}])
pprint.pprint(list(db.testcollection.find({}, {'_id': 0})))

col_name = "2020/08/24"
db.testcollection.update_many({}, {"$unset": {f"{col_name}": 1}})

pprint.pprint(list(db.testcollection.find({}, {'_id': 0})))

結果:

[{'2020/08/24': '1', '2020/08/25': '1.0', 'Site': 'ABCD'},
 {'2020/08/24': '1', '2020/08/25': '0.0', 'Site': 'EFGH'}]
[{'2020/08/25': '1.0', 'Site': 'ABCD'}, {'2020/08/25': '0.0', 'Site': 'EFGH'}]

以下代碼適用於 Python 3.8、PyMongo 3.11. 和 MongoDB v 4.2.8。

col_name = '2020/08/24'
result = collection.update_many( { }, { '$unset': { col_name: '' } } )
print(result.matched_count, result.modified_count)

更新了帖子中的兩個文檔,並刪除了名稱為"2020/08/24"的字段。 注意:MongoDB 集合的文檔可以具有帶/字符的字段名稱(請參閱文檔 - 字段名稱)。


[編輯添加]

以下delete_mongo_field函數通過刪除提供的字段名稱為我正確更新文檔工作:

def delete_mongo_field(db, collection, col_name, host, port):
    db = connect_mongo(host, port, db)
    result = db[collection].update_many( { }, { '$unset': { col_name: 1 } } ) # you can also use '' instead of 1
    print(result.modified_count)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM