diff --git a/docs/ricgraph_query_visualize.md b/docs/ricgraph_query_visualize.md index 7901cec..90d2ff7 100644 --- a/docs/ricgraph_query_visualize.md +++ b/docs/ricgraph_query_visualize.md @@ -161,6 +161,19 @@ Rules which determine the size of a node: the [Research Software Directory](https://research-software-directory.org). * all other nodes: size = medium. +### Export nodes +There are two scripts which allow to export *person* nodes to a csv file. These can be +found in the directory [export_ricgraph_examples](../export_ricgraph_examples). +* *export_person_identifiers.py*: exports + all [person identifiers](ricgraph_details.md#person-identifiers) + connected to a *person-root* node. +* *export_person_node_properties.py*: exports + all [node properties](ricgraph_details.md#properties-of-nodes-in-ricgraph) + for every *person* node connected to a *person-root* node. + +Use the parameter *EXPORT_MAX_RECS* for the number of records to export and +*EXPORT_FILENAME* for the filename to export at the start of both scripts. + ### Return to main README.md file [Return to main README.md file](../README.md). diff --git a/export_ricgraph_examples/export_person_identifiers.py b/export_ricgraph_examples/export_person_identifiers.py new file mode 100644 index 0000000..9a927b3 --- /dev/null +++ b/export_ricgraph_examples/export_person_identifiers.py @@ -0,0 +1,105 @@ +# ######################################################################## +# +# Ricgraph - Research in context graph +# +# ######################################################################## +# +# MIT License +# +# Copyright (c) 2023 Rik D.T. Janssen +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. +# +# ######################################################################## +# +# This file contains example code for Ricgraph. +# +# With this code, you can export all "person" nodes in Ricgraph to a csv file. +# You can set some parameters in the code following the "import" statements below. +# +# Original version Rik D.T. Janssen, April 2023. +# +# ######################################################################## + + +import pandas +import ricgraph as rcg + +EXPORT_FILENAME = 'ricgraph_export_person_identifiers.csv' +EXPORT_MAX_RECS = 0 # 0 = all records + + +# ############################################ +# ################### main ################### +# ############################################ +print('\nPreparing graph...') +graph = rcg.open_ricgraph() + +all_personroot_nodes = rcg.read_all_nodes(name='person-root') +if len(all_personroot_nodes) == 0: + print('No person-root nodes found, exiting.') + exit(0) + +result = pandas.DataFrame() +chunk = [] # list of dictionaries +all_records = 9999999999 # a large number +if EXPORT_MAX_RECS == 0: + print('There are ' + str(len(all_personroot_nodes)) + ' person-root nodes.') + max_nodes_to_export = all_records +else: + max_nodes_to_export = EXPORT_MAX_RECS + print('There are ' + str(len(all_personroot_nodes)) + ' person-root nodes, ' + + 'exporting at most ' + str(max_nodes_to_export) + ' nodes.') + +print('Exporting record: 0 ', end='', flush=True) +count = 0 +for personroot_node in all_personroot_nodes: + if count >= max_nodes_to_export: + break + + count += 1 + if count % 100 == 0: + print(count, ' ', end='', flush=True) + if count % 2000 == 0: + print('\n', end='', flush=True) + + neighbors = rcg.get_all_neighbor_nodes(personroot_node, category_want='person') + if len(neighbors) == 0: + continue + + for node in neighbors: + if node == personroot_node: + continue + + line = {} + line['person-root'] = str(personroot_node['value']) + line[node['name']] = str(node['value']) + line['_source'] = ','.join([str(source) for source in node['_source']]) + chunk.append(line) + +print(count, '\n', end='', flush=True) + +chunk_df = pandas.DataFrame(chunk) +result = pandas.concat([result, chunk_df], ignore_index=True) +# dropna(how='all'): drop row if all row values contain NaN +result.dropna(axis=0, how='all', inplace=True) +result.drop_duplicates(keep='first', inplace=True, ignore_index=True) +rcg.write_dataframe_to_csv(filename=EXPORT_FILENAME, df=result) + +rcg.close_ricgraph() diff --git a/export_ricgraph_examples/export_person_node_properties.py b/export_ricgraph_examples/export_person_node_properties.py new file mode 100644 index 0000000..9987dbc --- /dev/null +++ b/export_ricgraph_examples/export_person_node_properties.py @@ -0,0 +1,112 @@ +# ######################################################################## +# +# Ricgraph - Research in context graph +# +# ######################################################################## +# +# MIT License +# +# Copyright (c) 2023 Rik D.T. Janssen +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. +# +# ######################################################################## +# +# This file contains example code for Ricgraph. +# +# With this code, you can export every field in a "person" node +# in Ricgraph to a csv file, for all "person" nodes. +# You can set some parameters in the code following the "import" statements below. +# +# Original version Rik D.T. Janssen, April 2023. +# +# ######################################################################## + + +import pandas +import ricgraph as rcg + +EXPORT_FILENAME = 'ricgraph_export_node_properties.csv' +EXPORT_MAX_RECS = 0 # 0 = all records +EXPORT_PROPERTIES = rcg.RICGRAPH_PROPERTIES_STANDARD + ('_source',) + + +# ############################################ +# ################### main ################### +# ############################################ +print('\nPreparing graph...') +graph = rcg.open_ricgraph() + +all_personroot_nodes = rcg.read_all_nodes(name='person-root') +if len(all_personroot_nodes) == 0: + print('No person-root nodes found, exiting.') + exit(0) + +result = pandas.DataFrame() +chunk = [] # list of dictionaries +all_records = 9999999999 # a large number +if EXPORT_MAX_RECS == 0: + print('There are ' + str(len(all_personroot_nodes)) + ' person-root nodes.') + max_nodes_to_export = all_records +else: + max_nodes_to_export = EXPORT_MAX_RECS + print('There are ' + str(len(all_personroot_nodes)) + ' person-root nodes, ' + + 'exporting at most ' + str(max_nodes_to_export) + ' nodes.') + +print('Exporting record: 0 ', end='', flush=True) +count = 0 +export_properties = EXPORT_PROPERTIES + rcg.RICGRAPH_PROPERTIES_ADDITIONAL +for personroot_node in all_personroot_nodes: + if count >= max_nodes_to_export: + break + + count += 1 + if count % 100 == 0: + print(count, ' ', end='', flush=True) + if count % 2000 == 0: + print('\n', end='', flush=True) + + neighbors = rcg.get_all_neighbor_nodes(personroot_node, category_want='person') + if len(neighbors) == 0: + continue + + for node in neighbors: + if node == personroot_node: + continue + + line = {} + for prop_node in export_properties: + line['person-root'] = str(personroot_node['value']) + if prop_node == '_source': + line[prop_node] = ','.join([str(source) for source in node[prop_node]]) + else: + line[prop_node] = str(node[prop_node]) + + chunk.append(line) + +print(count, '\n', end='', flush=True) + +chunk_df = pandas.DataFrame(chunk) +result = pandas.concat([result, chunk_df], ignore_index=True) +# dropna(how='all'): drop row if all row values contain NaN +result.dropna(axis=0, how='all', inplace=True) +result.drop_duplicates(keep='first', inplace=True, ignore_index=True) +rcg.write_dataframe_to_csv(filename=EXPORT_FILENAME, df=result) + +rcg.close_ricgraph()