當前位置: 首頁>>代碼示例>>Python>>正文


Python gridfs.GridFS方法代碼示例

本文整理匯總了Python中gridfs.GridFS方法的典型用法代碼示例。如果您正苦於以下問題:Python gridfs.GridFS方法的具體用法?Python gridfs.GridFS怎麽用?Python gridfs.GridFS使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在gridfs的用法示例。


在下文中一共展示了gridfs.GridFS方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: save_memory_to_db

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def save_memory_to_db(self, env, name):
        try:
            env.logger.info(ArenaDDPGAgent.save_to_db, "Trying to save memory to database.")

            memory = pickle.dumps(self.memory)

            fs = gd.GridFS(env.db, collection=name+'_memory')

            fs.put(memory)

            del fs

            env.logger.info(ArenaDDPGAgent.save_to_db, "Memory saved to db!")

        except Exception as e:
            env.logger.error(ArenaDDPGAgent.save_to_db, env.parse_error(e)) 
開發者ID:naripok,項目名稱:cryptotrader,代碼行數:18,代碼來源:tf_agents.py

示例2: get

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def get(self, _id, mode='r'):
            """Open the file with the specified id.

            .. warning::

                To avoid compatiblity issues, all files are
                opened in text-mode (`r`) by default, however
                for higher efficiency, files should generally
                be opened in binary mode (`rb`) whenever possible.

            :param _id: The file identifier.
            :type _id: str
            :param mode: The file mode used for opening.
            :returns: A file-like object to read from."""
            if mode == 'r':
                file = io.StringIO(self.gridfs.get(_id).read().decode())
                if len(file.getvalue()) > GRIDFS_LARGE_FILE_WARNING_THRSHLD:
                    warnings.warn(
                        "Open large GridFS files more efficiently in 'rb' mode.")
                return file
            elif mode == 'rb':
                return self.gridfs.get(file_id=_id)
            else:
                raise ValueError(mode) 
開發者ID:glotzerlab,項目名稱:signac,代碼行數:26,代碼來源:filesystems.py

示例3: connect

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def connect(self):
        """Connects to Mongo database, loads options and set connectors.
        @raise CuckooReportError: if unable to connect.
        """
        host = self.options.get("host", "127.0.0.1")
        port = self.options.get("port", 27017)
        db = self.options.get("db", "cuckoo")

        try:
            self.conn = MongoClient(host, port)
            self.db = self.conn[db]
            self.fs = GridFS(self.db)
        except TypeError:
            raise CuckooReportError("Mongo connection port must be integer")
        except ConnectionFailure:
            raise CuckooReportError("Cannot connect to MongoDB") 
開發者ID:davidoren,項目名稱:CuckooSploit,代碼行數:18,代碼來源:mongodb.py

示例4: testCode4

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def testCode4():
    inicio = 10569000
    client = MongoClient(envget('files.host'), envget('files.port'))
    db = client[envget('db_files_name')]
    fs = gridfs.GridFS(db)
    res = fs.find(timeout=False).skip(inicio)
    lc = Launcher()
    count = inicio
    reset = 0
    for f in res:
        data = f.read()
        # print(f.filename,count)
        lc.launchFileAnalitics((f.filename, data))
        reset += 1
        count += 1
        if(reset >= 1000):
            print(str(count) + " processed")
            reset = 0
    print(str(count) + " processed")

# ---------------------------------------------- 
開發者ID:codexgigassys,項目名稱:codex-backend,代碼行數:23,代碼來源:Launcher.py

示例5: remove

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def remove(self, workflow_id):
        """ Removes a document specified by its id from the data store.

        All associated GridFs documents are deleted as well.

        Args:
            workflow_id (str): The id of the document that represents a workflow run.

        Raises:
            DataStoreNotConnected: If the data store is not connected to the server.
        """
        try:
            db = self._client[self.database]
            fs = GridFSProxy(GridFS(db.unproxied_object))

            for grid_doc in fs.find({"workflow_id": workflow_id},
                                    no_cursor_timeout=True):
                fs.delete(grid_doc._id)

            col = db[WORKFLOW_DATA_COLLECTION_NAME]
            return col.delete_one({"_id": ObjectId(workflow_id)})

        except ConnectionFailure:
            raise DataStoreNotConnected() 
開發者ID:AustralianSynchrotron,項目名稱:lightflow,代碼行數:26,代碼來源:datastore.py

示例6: get

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def get(self, workflow_id):
        """ Returns the document for the given workflow id.

        Args:
            workflow_id (str): The id of the document that represents a workflow run.

        Raises:
            DataStoreNotConnected: If the data store is not connected to the server.

        Returns:
            DataStoreDocument: The document for the given workflow id.
        """
        try:
            db = self._client[self.database]
            fs = GridFSProxy(GridFS(db.unproxied_object))
            return DataStoreDocument(db[WORKFLOW_DATA_COLLECTION_NAME], fs, workflow_id)

        except ConnectionFailure:
            raise DataStoreNotConnected() 
開發者ID:AustralianSynchrotron,項目名稱:lightflow,代碼行數:21,代碼來源:datastore.py

示例7: _encode_value

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def _encode_value(self, value):
        """ Encodes the value such that it can be stored into MongoDB.

        Any primitive types are stored directly into MongoDB, while non-primitive types
        are pickled and stored as GridFS objects. The id pointing to a GridFS object
        replaces the original value.

        Args:
            value (object): The object that should be encoded for storing in MongoDB.

        Returns:
            object: The encoded value ready to be stored in MongoDB.
        """
        if isinstance(value, (int, float, str, bool, datetime)):
            return value
        elif isinstance(value, list):
            return [self._encode_value(item) for item in value]
        elif isinstance(value, dict):
            result = {}
            for key, item in value.items():
                result[key] = self._encode_value(item)
            return result
        else:
            return self._gridfs.put(Binary(pickle.dumps(value)),
                                    workflow_id=self._workflow_id) 
開發者ID:AustralianSynchrotron,項目名稱:lightflow,代碼行數:27,代碼來源:datastore.py

示例8: __init__

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def __init__(self):
        if MONGO:
            # Create the connection
            mongo_uri = config.TannerConfig.get('MONGO', 'URI')

            connection = pymongo.MongoClient(mongo_uri)

            # Connect to Databases.
            tandb = connection['tanner']
            tandbfs = connection['voldbfs']

            # Get Collections
            self.tan_sessions = tandb.sessions
            self.tan_files = GridFS(tandbfs)

            # Indexes
            self.tan_sessions.create_index([('$**', 'text')])
        else:
            print('pymongo not found. pip install pymongo') 
開發者ID:mushorg,項目名稱:tanner,代碼行數:21,代碼來源:log_mongodb.py

示例9: update_plugin

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def update_plugin(self, plugin_id, new_values):
        plugin_id = ObjectId(plugin_id)
        if len(str(new_values)) > 12000000:
            print "Storing Large Document in GridFS"
            large_document = json.dumps(new_values['plugin_output'])
            large_document_id = self.create_file(large_document, 'sess_id', 'sha256', 'filename', pid=None, file_meta=None)
            new_values['plugin_output'] = large_document_id
            new_values['largedoc'] = 'True'

        self.vol_plugins.update_one({'_id': plugin_id}, {"$set": new_values})
        return True


    ##
    # File System
    ## 
開發者ID:kevthehermit,項目名稱:VolUtility,代碼行數:18,代碼來源:database.py

示例10: mongo_obs

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def mongo_obs(monkeypatch):
    client = ReconnectingMongoClient(
        max_calls_before_reconnect=10,
        max_calls_before_failure=1,
        exception_to_raise=pymongo.errors.ServerSelectionTimeoutError,
    )
    fs = gridfs.GridFS(client.sacred)
    monkeypatch.setattr(pymongo, "MongoClient", lambda *args, **kwargs: client)
    monkeypatch.setattr(gridfs, "GridFS", lambda _: fs)

    return QueuedMongoObserver(interval=0.01, retry_interval=0.01) 
開發者ID:IDSIA,項目名稱:sacred,代碼行數:13,代碼來源:test_queue_mongo_observer.py

示例11: mongo_obs

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def mongo_obs():
    db = mongomock.MongoClient().db
    runs = db.runs
    metrics = db.metrics
    fs = gridfs.GridFS(db)
    return MongoObserver.create_from(runs, fs, metrics_collection=metrics) 
開發者ID:IDSIA,項目名稱:sacred,代碼行數:8,代碼來源:test_mongo_observer.py

示例12: failing_mongo_observer

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def failing_mongo_observer():
    db = FailingMongoClient(
        max_calls_before_failure=2,
        exception_to_raise=pymongo.errors.ServerSelectionTimeoutError,
    ).db

    runs = db.runs
    metrics = db.metrics
    fs = gridfs.GridFS(db)
    return MongoObserver.create_from(runs, fs, metrics_collection=metrics) 
開發者ID:IDSIA,項目名稱:sacred,代碼行數:12,代碼來源:test_mongo_observer.py

示例13: __init__

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def __init__(self, client, db='retelogs', collection=None):
        self.client = MongoClient(client)
        self.db = self.client[db]
        self.collection = collection or 'pictures'
        self.fs = gridfs.GridFS(self.db, collection) 
開發者ID:retentioneering,項目名稱:retentioneering-tools,代碼行數:7,代碼來源:cloud_logger.py

示例14: load_memory_from_db

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def load_memory_from_db(self, env, number=-1):
        try:
            col_names = env.db.collection_names()

            if self.name + '_memory' + '.chunks' not in col_names:

                print("Choice the table number containing the memory buffer to be loaded:\n")
                for i, table in enumerate(env.db.collection_names()):
                    print("Table {2}: {0}, count: {1}".format(table, env.db[table].count(), i))
                table_n = input("Enter the table number or press ENTER:")
                if not table_n:
                    print("Load memory skiped.")
                    return
                elif table_n == '':
                    print("Load memory skiped.")
                    return
                else:
                    memory_name = col_names[int(table_n)].strip('.chunks')
            else:
                memory_name = self.name + '_memory'

            env.logger.info(ArenaDDPGAgent.load_from_db, "Trying to read data from " + memory_name)

            fs = gd.GridFS(env.db, collection=memory_name)

            memory = pickle.loads(fs.find().sort('uploadDate', -1).skip(abs(number)-1).limit(-1).next().read())

            del fs

            self.memory = memory

            env.logger.info(ArenaDDPGAgent.load_from_db, "Memory buffer loaded from " + memory_name)

        except Exception as e:
            env.logger.error(ArenaDDPGAgent.load_memory_from_db, env.parse_error(e)) 
開發者ID:naripok,項目名稱:cryptotrader,代碼行數:37,代碼來源:tf_agents.py

示例15: save_to_db

# 需要導入模塊: import gridfs [as 別名]
# 或者: from gridfs import GridFS [as 別名]
def save_to_db(self, env, name, overwrite=False):
        try:
            timestamp = datetime.utcnow()

            env.logger.info(ArenaDDPGAgent.save_to_db, "Trying to save model to database. Weights version: %d" %
                            (self.weights_version))

            data = {'index': timestamp,
                    'weights_version': self.weights_version + 1,
                    # 'agent_params': pickle.dumps(agent_params),
                    'actor_config': pickle.dumps(self.actor.to_json()),
                    'critic_config': pickle.dumps(self.critic.to_json()),
                    'actor_weights': pickle.dumps(self.actor.get_weights()),
                    'critic_weights': pickle.dumps(self.critic.get_weights()),
                    # 'memory': pickle.dumps(self.memory)
                    }

            fs = gd.GridFS(env.db, collection=name)

            fs.put(pickle.dumps(data))

            del fs

            env.logger.info(ArenaDDPGAgent.save_to_db, "Model weights saved to db!")

        except Exception as e:
            env.logger.error(ArenaDDPGAgent.save_to_db, env.parse_error(e)) 
開發者ID:naripok,項目名稱:cryptotrader,代碼行數:29,代碼來源:tf_agents.py


注:本文中的gridfs.GridFS方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。