Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nicolewhite/RNeo4j
Neo4j Driver for R.
https://github.com/nicolewhite/RNeo4j
Last synced: 3 months ago
JSON representation
Neo4j Driver for R.
- Host: GitHub
- URL: https://github.com/nicolewhite/RNeo4j
- Owner: nicolewhite
- License: other
- Archived: true
- Created: 2014-05-08T07:56:49.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2019-02-19T15:23:19.000Z (almost 6 years ago)
- Last Synced: 2024-08-02T07:10:34.335Z (6 months ago)
- Language: R
- Homepage: https://cran.r-project.org/web/packages/RNeo4j/
- Size: 936 KB
- Stars: 239
- Watchers: 53
- Forks: 69
- Open Issues: 21
-
Metadata Files:
- Readme: README.Rmd
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-neo4j - RNeo4j - Driver for R. (REST API / Other)
README
# RNeo4j [![Build Status](https://travis-ci.org/nicolewhite/RNeo4j.svg?branch=master)](https://travis-ci.org/nicolewhite/RNeo4j)
RNeo4j is Neo4j's R driver. It allows you to read and write data from / to Neo4j directly from your R environment.
## Contents
* [Install](#install)
* [Connect](#connect)
* [Nodes](#nodes)
* [Relationships](#relationships)
* [Cypher](#cypher)
* [Shortest Paths](#shortest-paths)
* [Weighted Shortest Paths](#weighted-shortest-paths)
* [Graph Algorithms](#graph-algorithms)
* [Visualizations](#visualizations)
* [Import](#import)
* [Connection Issues](#connection-issues)
* [Contribute](#contribute)### Neo4j
First and foremost, [download Neo4j](http://neo4j.com/download/other-releases/)!
#### Windows
If you're on Windows, download the `.exe` and follow the instructions. You'll get a GUI where you simply press "Start" to start Neo4j.
#### OS X
If you're on OS X, you can download either the `.dmg` or the `.tar.gz`. The `.dmg` will give you a GUI where you simply press "Start" to start Neo4j. Otherwise, download the `.tar.gz`, unzip, navigate to the directory and execute `./bin/neo4j start`.
#### Linux
If you're on Linux, you have to use the `.tar.gz`. Download the `.tar.gz`, unzip, navigate to the directory and execute `./bin/neo4j start`.
### Bolt dependencies
These depencies are are only required if you want to use the Bolt interface.
They must be present at build time, and `libneo4j-client` must also be present at runtime.#### Windows
- Rust: https://rustup.rs
- Clang: binary releases are available at http://releases.llvm.org/download.html
- libneo4j-client:
- Make sure you have RTools installed (necessary for building R packages on Windows)
- Open your MinGW shell (check in start menu, `C:\RTools\mingw_64`, `C:\RTools\mingw_32`, `C:\MinGW\bin`, and `C:\MinGW\1.0\bin`)
- See "Installing libneo4j-from source" section#### OS X (with Homebrew installed)
- Rust: `brew install rust` (or https://rustup.rs but see "Rust Path" section)
- Clang: `brew install llvm`
- libneo4j-client: `brew install cleishm/neo4j/libneo4j-client`#### Linux
- Rust:
- Debian based (e.g. Mint, Ubuntu): `sudo apt-get install cargo`
- Arch Linux: `sudo pacman -S rust`
- Building from source: https://rustup.rs but see "Rust Path" section
- Clang: get it from your package manager
- Debian based (e.g. Mint, Ubuntu): `sudo apt-get install clang libclang-dev`
- Arch Linux: `sudo pacman -S clang`
- Other: your package manager almost certainly has `clang`. It may be called `llvm`.
- libneo4j-client:
- Debian based: `sudo apt-get install libneo4j-client-dev`
- Other: See "Installing libneo4j-client from source"#### Rust Path
By default, on *nix systems (such as Linux and OS X), rustup only sets the PATH in your shell.
That means that if you try to build RNeo4j in a GUI application like RStudio, it may fail.
To work around this issue, simply build RNeo4j in a terminal.### RNeo4j
#### From CRAN
```{r, eval=FALSE}
install.packages("RNeo4j")
```#### From GitHub
```{r, eval=FALSE}
devtools::install_github("nicolewhite/RNeo4j")
```#### From Source
Go to the [latest release](https://github.com/nicolewhite/RNeo4j/releases/latest) and download the source code. You can then install with `install.packages`.
```{r, eval=FALSE}
install.packages("/path/to/file.tar.gz", repos=NULL, type="source")
```#### Load the Package
```{r}
library(RNeo4j)
``````{r, eval=FALSE}
graph = startGraph("http://localhost:7474/db/data/")
```If you have authentication enabled, pass your username and password.
```{r}
graph = startGraph("http://localhost:7474/db/data/", username="neo4j", password="password")
``````{r, echo=FALSE}
clear(graph, input=F)
``````{r}
nicole = createNode(graph, "Person", name="Nicole", age=24)
greta = createNode(graph, "Person", name="Greta", age=24)
kenny = createNode(graph, "Person", name="Kenny", age=27)
shannon = createNode(graph, "Person", name="Shannon", age=23)
``````{r}
r1 = createRel(greta, "LIKES", nicole, weight=7)
r2 = createRel(nicole, "LIKES", kenny, weight=1)
r3 = createRel(kenny, "LIKES", shannon, weight=3)
r4 = createRel(nicole, "LIKES", shannon, weight=5)
```If you're returning tabular results, use `cypher`, which will give you a `data.frame`.
```{r}
query = "
MATCH (nicole:Person)-[r:LIKES]->(p:Person)
WHERE nicole.name = 'Nicole'
RETURN nicole.name, r.weight, p.name
"cypher(graph, query)
```For anything more complicated, use `cypherToList`, which will give you a `list`.
```{r}
query = "
MATCH (nicole:Person)-[:LIKES]->(p:Person)
WHERE nicole.name = 'Nicole'
RETURN nicole, COLLECT(p.name) AS friends
"cypherToList(graph, query)
```Both `cypher` and `cypherToList` accept parameters. These parameters can be passed individually or as a list.
```{r}
query = "
MATCH (p1:Person)-[r:LIKES]->(p2:Person)
WHERE p1.name = {name1} AND p2.name = {name2}
RETURN p1.name, r.weight, p2.name
"cypher(graph, query, name1="Nicole", name2="Shannon")
cypher(graph, query, list(name1="Nicole", name2="Shannon"))
``````{r}
p = shortestPath(greta, "LIKES", shannon, max_depth=4)
n = nodes(p)
sapply(n, "[[", "name")
``````{r}
p = shortestPath(greta, "LIKES", shannon, max_depth=4, cost_property="weight")
n = nodes(p)
sapply(n, "[[", "name")
p$weight
``````{r, message=FALSE}
library(igraph)query = "
MATCH (n)-->(m)
RETURN n.name, m.name
"edgelist = cypher(graph, query)
ig = graph.data.frame(edgelist, directed=F)betweenness(ig)
closeness(ig)
```### `igraph`
```{r, message=FALSE}
plot(ig)
```### `ggnet`
```{r, message=FALSE}
library(network)
library(GGally)net = network(edgelist)
ggnet(net, label.nodes=TRUE)
```### `visNetwork`
[Read this blog post](http://neo4j.com/blog/visualize-graph-with-rneo4j/) and [check out this slide deck](http://nicolewhite.github.io/neo4j-presentations/RNeo4j/Visualizations/Visualizations.html#1).
```{r, echo=FALSE}
clear(graph, input=F)
``````{r}
library(hflights)
hflights = hflights[sample(nrow(hflights), 1000), ]
row.names(hflights) = NULLhead(hflights)
addConstraint(graph, "Carrier", "name")
addConstraint(graph, "Airport", "name")query = "
CREATE (flight:Flight {number: {FlightNum} })
SET flight.year = TOINT({Year}),
flight.month = TOINT({DayofMonth}),
flight.day = TOINT({DayOfWeek})MERGE (carrier:Carrier {name: {UniqueCarrier} })
CREATE (flight)-[:OPERATED_BY]->(carrier)MERGE (origin:Airport {name: {Origin} })
MERGE (dest:Airport {name: {Dest} })CREATE (flight)-[o:ORIGIN]->(origin)
CREATE (flight)-[d:DESTINATION]->(dest)SET o.delay = TOINT({DepDelay}),
o.taxi_time = TOINT({TaxiOut})SET d.delay = TOINT({ArrDelay}),
d.taxi_time = TOINT({TaxiIn})
"tx = newTransaction(graph)
for(i in 1:nrow(hflights)) {
row = hflights[i, ]
appendCypher(tx, query,
FlightNum=row$FlightNum,
Year=row$Year,
DayofMonth=row$DayofMonth,
DayOfWeek=row$DayOfWeek,
UniqueCarrier=row$UniqueCarrier,
Origin=row$Origin,
Dest=row$Dest,
DepDelay=row$DepDelay,
TaxiOut=row$TaxiOut,
ArrDelay=row$ArrDelay,
TaxiIn=row$TaxiIn)
}commit(tx)
summary(graph)
```### Couldn't connect to server
```
Error in curl::curl_fetch_memory(url, handle = handle) :
Couldn't connect to server
```Neo4j probably isn't running. Make sure Neo4j is running first. It's also possible you have localhost resolution issues; try connecting to `http://127.0.0.1:7474/db/data/` instead.
### No authorization header supplied
```
Error: client error: (401) Unauthorized
Neo.ClientError.Security.AuthorizationFailed
No authorization header supplied.
```You have auth enabled on Neo4j and either didn't provide your username and password or they were invalid. You can pass a username and password to `startGraph`.
```
graph = startGraph("http://localhost:7474/db/data/", username="neo4j", password="password")
```You can also disable auth by editing the following line in `conf/neo4j-server.properties`.
```
# Require (or disable the requirement of) auth to access Neo4j
dbms.security.auth_enabled=false
```Check out [the contributing doc](https://github.com/nicolewhite/RNeo4j/blob/master/CONTRIBUTING.md) if you'd like to contribute!