{
  "_id": "6a4790148b9f0d9747cf1441",
  "Package": "textshape",
  "Title": "Tools for Reshaping Text",
  "Version": "1.7.6",
  "Authors@R": "c(\nperson(\"Tyler\", \"Rinker\", email = \"tyler.rinker@gmail.com\", role = c(\"aut\", \"cre\")),\nperson(\"Joran\", \"Elias\", role = \"ctb\"),\nperson(\"Matthew\", \"Flickinger\", role = \"ctb\"),\nperson('Paul', 'Foster', role = \"ctb\")\n)",
  "Maintainer": "Tyler Rinker <tyler.rinker@gmail.com>",
  "Description": "Tools that can be used to reshape and restructure text\ndata.",
  "License": "GPL-2",
  "LazyData": "TRUE",
  "RoxygenNote": "7.2.3",
  "Encoding": "UTF-8",
  "URL": "https://github.com/trinker/textshape",
  "BugReports": "https://github.com/trinker/textshape/issues",
  "Collate": "'bind_list.R' 'bind_table.R' 'bind_vector.R' 'change_index.R'\n'cluster_matrix.R' 'column_to_rownames.R' 'combine.R'\n'duration.R' 'flatten.R' 'from_to.R' 'grab_index.R'\n'grab_match.R' 'mtabulate.R' 'split_index.R' 'split_match.R'\n'split_match_regex_to_transcript.R' 'split_portion.R'\n'split_run.R' 'split_sentence.R' 'split_sentence_token.R'\n'split_speaker.R' 'split_token.R' 'split_transcript.R'\n'split_word.R' 'textshape-package.R' 'tidy_colo_dtm.R'\n'utils.R' 'tidy_dtm.R' 'tidy_list.R' 'tidy_matrix.R'\n'tidy_table.R' 'tidy_vector.R' 'unique_pairs.R' 'unnest_text.R'",
  "Config/pak/sysreqs": "libicu-dev",
  "Repository": "https://trinker.r-universe.dev",
  "Date/Publication": "2024-04-01 17:35:11 UTC",
  "RemoteUrl": "https://github.com/trinker/textshape",
  "RemoteRef": "HEAD",
  "RemoteSha": "61dc5f1e0ba817571d97d87751959f78613ad92c",
  "NeedsCompilation": "no",
  "Packaged": {
    "Date": "2026-07-02 08:41:40 UTC",
    "User": "root"
  },
  "Author": "Tyler Rinker [aut, cre],\nJoran Elias [ctb],\nMatthew Flickinger [ctb],\nPaul Foster [ctb]",
  "_user": "trinker",
  "_type": "src",
  "_file": "textshape_1.7.6.tar.gz",
  "_fileid": "https://r2.ropensci.org/7ac69696fb0694a7f8bac8349d281df2aefc6680690781d796dbb738d3e6939e",
  "_filesize": 902545,
  "_sha256": "7ac69696fb0694a7f8bac8349d281df2aefc6680690781d796dbb738d3e6939e",
  "_expires": "2026-10-11T10:33:56.000Z",
  "_created": "2026-07-02T08:41:40.000Z",
  "_published": "2026-07-03T10:33:56.562Z",
  "_jobs": [
    {
      "job": 84981594802,
      "time": 117,
      "config": "linux-devel-x86_64",
      "r": "4.7.0",
      "check": "OK",
      "artifact": "8033432791"
    },
    {
      "job": 84981595062,
      "time": 132,
      "config": "linux-release-x86_64",
      "r": "4.6.1",
      "check": "OK",
      "artifact": "8033438438"
    },
    {
      "job": 84981594809,
      "time": 112,
      "config": "macos-oldrel-arm64",
      "r": "4.5.3",
      "check": "OK",
      "artifact": "8033430811"
    },
    {
      "job": 84981594890,
      "time": 82,
      "config": "macos-release-arm64",
      "r": "4.6.1",
      "check": "OK",
      "artifact": "8033420031"
    },
    {
      "job": 84981594778,
      "time": 148,
      "config": "source",
      "r": "4.6.1",
      "check": "OK",
      "artifact": "8033387620"
    },
    {
      "job": 84981594908,
      "time": 103,
      "config": "wasm-release",
      "r": "4.6.0",
      "check": "OK",
      "artifact": "8033427558"
    },
    {
      "job": 84981594924,
      "time": 76,
      "config": "windows-devel",
      "r": "4.7.0",
      "check": "OK",
      "artifact": "8033417857"
    },
    {
      "job": 84981595069,
      "time": 95,
      "config": "windows-oldrel",
      "r": "4.5.3",
      "check": "OK",
      "artifact": "8033425013"
    },
    {
      "job": 84981594816,
      "time": 86,
      "config": "windows-release",
      "r": "4.6.1",
      "check": "OK",
      "artifact": "8033421233"
    }
  ],
  "_host": "GitHub-Actions",
  "_buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206",
  "_status": "success",
  "_upstream": "https://github.com/trinker/textshape",
  "_commit": {
    "id": "61dc5f1e0ba817571d97d87751959f78613ad92c",
    "author": "Tyler Rinker <tyler.rinker@kangarootime.com>",
    "committer": "Tyler Rinker <tyler.rinker@kangarootime.com>",
    "message": "Merge branch 'master' of https://github.com/trinker/textshape\n",
    "time": 1711992911
  },
  "_maintainer": {
    "name": "Tyler Rinker",
    "email": "tyler.rinker@gmail.com",
    "login": "trinker",
    "description": "Director, Data Scientist, open-source developer , #python/#rstats enthusiast, #dataviz geek, and #nlp buff",
    "uuid": 1763278
  },
  "_distro": "resolute",
  "_registered": true,
  "_dependencies": [
    {
      "package": "R",
      "version": ">= 3.4.0",
      "role": "Depends"
    },
    {
      "package": "data.table",
      "role": "Imports"
    },
    {
      "package": "slam",
      "role": "Imports"
    },
    {
      "package": "stats",
      "role": "Imports"
    },
    {
      "package": "stringi",
      "role": "Imports"
    },
    {
      "package": "utils",
      "role": "Imports"
    },
    {
      "package": "testthat",
      "role": "Suggests"
    }
  ],
  "_owner": "trinker",
  "_selfowned": true,
  "_usedby": 40,
  "_updates": [],
  "_tags": [],
  "_topics": [
    "data-reshaping",
    "manipulation",
    "sentence-boundary-detection",
    "text-data",
    "text-formating",
    "tidy"
  ],
  "_stars": 53,
  "_contributors": [
    {
      "user": "trinker",
      "count": 126,
      "uuid": 1763278
    },
    {
      "user": "tylerrinker-dev",
      "count": 3,
      "uuid": 237491193
    }
  ],
  "_userbio": {
    "uuid": 1763278,
    "type": "user",
    "name": "Tyler Rinker",
    "followers": 623,
    "description": "Director, Data Scientist, open-source developer , #python/#rstats enthusiast, #dataviz geek, and #nlp buff"
  },
  "_downloads": {
    "count": 5713,
    "source": "https://cranlogs.r-pkg.org/downloads/total/last-month/textshape"
  },
  "_devurl": "https://github.com/trinker/textshape",
  "_searchresults": 538,
  "_rbuild": "4.6.1",
  "_assets": [
    "extra/citation.cff",
    "extra/citation.html",
    "extra/citation.json",
    "extra/citation.txt",
    "extra/contents.json",
    "extra/readme.html",
    "extra/readme.md",
    "extra/textshape.html",
    "manual.pdf"
  ],
  "_homeurl": "https://github.com/trinker/textshape",
  "_realowner": "trinker",
  "_cranurl": true,
  "_releases": [
    {
      "version": "0.2.0",
      "date": "2016-12-31"
    },
    {
      "version": "1.0.0",
      "date": "2017-01-10"
    },
    {
      "version": "1.0.1",
      "date": "2017-01-20"
    },
    {
      "version": "1.0.2",
      "date": "2017-02-22"
    },
    {
      "version": "1.3.0",
      "date": "2017-07-27"
    },
    {
      "version": "1.5.0",
      "date": "2017-09-08"
    },
    {
      "version": "1.6.0",
      "date": "2018-06-07"
    },
    {
      "version": "1.7.1",
      "date": "2020-04-17"
    },
    {
      "version": "1.7.3",
      "date": "2021-05-28"
    },
    {
      "version": "1.7.5",
      "date": "2024-04-02"
    }
  ],
  "_exports": [
    "as_list",
    "bind_list",
    "bind_table",
    "bind_vector",
    "change_index",
    "cluster_matrix",
    "column_to_rownames",
    "combine",
    "duration",
    "ends",
    "flatten",
    "from_to",
    "from_to_summarize",
    "grab_index",
    "grab_match",
    "mtabulate",
    "split_index",
    "split_match",
    "split_match_regex",
    "split_portion",
    "split_run",
    "split_sentence",
    "split_sentence_token",
    "split_speaker",
    "split_token",
    "split_transcript",
    "split_word",
    "starts",
    "tidy_adjacency_matrix",
    "tidy_colo_dtm",
    "tidy_colo_tdm",
    "tidy_dtm",
    "tidy_list",
    "tidy_matrix",
    "tidy_table",
    "tidy_tdm",
    "tidy_vector",
    "unique_pairs",
    "unnest_text"
  ],
  "_datasets": [
    {
      "name": "DATA",
      "title": "Fictitious Classroom Dialogue",
      "object": "DATA",
      "class": [
        "data.frame"
      ],
      "fields": [
        "person",
        "sex",
        "adult",
        "state",
        "code"
      ],
      "rows": 11,
      "table": true,
      "tojson": true
    },
    {
      "name": "golden_rules",
      "title": "Sentence Boundary Disambiguation Edge Cases",
      "object": "golden_rules",
      "class": [
        "tbl_df",
        "tbl",
        "data.frame"
      ],
      "fields": [
        "Rule",
        "Text",
        "Outcome"
      ],
      "rows": 45,
      "table": false,
      "tojson": true
    },
    {
      "name": "hamlet",
      "title": "Hamlet (Complete & Split by Sentence)",
      "object": "hamlet",
      "class": [
        "qdap_df",
        "sent_split",
        "sent_split_text_var:dialogue",
        "data.frame"
      ],
      "fields": [
        "act",
        "tot",
        "scene",
        "location",
        "person",
        "died",
        "dialogue"
      ],
      "rows": 2007,
      "table": true,
      "tojson": true
    },
    {
      "name": "simple_dtm",
      "title": "Simple 'DocumentTermMatrix'",
      "object": "simple_dtm",
      "class": [
        "DocumentTermMatrix",
        "simple_triplet_matrix"
      ],
      "fields": [],
      "table": false,
      "tojson": false
    }
  ],
  "_help": [
    {
      "page": "bind_list",
      "title": "Row Bind a List of Named Dataframes or Vectors",
      "topics": [
        "bind_list"
      ]
    },
    {
      "page": "bind_table",
      "title": "Column Bind a Table's Values with Its Names",
      "topics": [
        "bind_table"
      ]
    },
    {
      "page": "bind_vector",
      "title": "Column Bind an Atomic Vector's Values with Its Names",
      "topics": [
        "bind_vector"
      ]
    },
    {
      "page": "change_index",
      "title": "Indexing of Changes in Runs",
      "topics": [
        "change_index"
      ]
    },
    {
      "page": "cluster_matrix",
      "title": "Reorder a Matrix Based on Hierarchical Clustering",
      "topics": [
        "cluster_matrix"
      ]
    },
    {
      "page": "column_to_rownames",
      "title": "Add a Column as Rownames",
      "topics": [
        "column_to_rownames"
      ]
    },
    {
      "page": "combine",
      "title": "Combine Elements",
      "topics": [
        "combine",
        "combine.data.frame",
        "combine.default"
      ]
    },
    {
      "page": "DATA",
      "title": "Fictitious Classroom Dialogue",
      "topics": [
        "DATA"
      ]
    },
    {
      "page": "duration",
      "title": "Duration of Turns of Talk",
      "topics": [
        "duration",
        "duration.data.frame",
        "duration.default",
        "duration.numeric",
        "ends",
        "starts"
      ]
    },
    {
      "page": "flatten",
      "title": "Flatten a Nested List of Vectors Into a Single Tier List of Vectors",
      "topics": [
        "flatten"
      ]
    },
    {
      "page": "from_to",
      "title": "Prepare Discourse Data for Network Plotting",
      "topics": [
        "from_to",
        "from_to.character",
        "from_to.data.frame",
        "from_to.default",
        "from_to.factor",
        "from_to.numeric",
        "from_to_summarize"
      ]
    },
    {
      "page": "golden_rules",
      "title": "Sentence Boundary Disambiguation Edge Cases",
      "topics": [
        "golden_rules"
      ]
    },
    {
      "page": "grab_index",
      "title": "Get Elements Matching Between 2 Points",
      "topics": [
        "grab_index",
        "grab_index.character",
        "grab_index.data.frame",
        "grab_index.default",
        "grab_index.list",
        "grab_index.matrix"
      ]
    },
    {
      "page": "grab_match",
      "title": "Get Elements Matching Between 2 Points",
      "topics": [
        "grab_match",
        "grab_match.character",
        "grab_match.data.frame",
        "grab_match.list"
      ]
    },
    {
      "page": "hamlet",
      "title": "Hamlet (Complete & Split by Sentence)",
      "topics": [
        "hamlet"
      ]
    },
    {
      "page": "mtabulate",
      "title": "Tabulate Frequency Counts for Multiple Vectors",
      "topics": [
        "as_list",
        "mtabulate"
      ]
    },
    {
      "page": "simple_dtm",
      "title": "Simple 'DocumentTermMatrix'",
      "topics": [
        "simple_dtm"
      ]
    },
    {
      "page": "split_index",
      "title": "Split Data Forms at Specified Indices",
      "topics": [
        "split_index",
        "split_index.character",
        "split_index.data.frame",
        "split_index.default",
        "split_index.factor",
        "split_index.list",
        "split_index.matrix",
        "split_index.numeric"
      ]
    },
    {
      "page": "split_match",
      "title": "Split a Vector By Split Points",
      "topics": [
        "split_match",
        "split_match_regex"
      ]
    },
    {
      "page": "split_portion",
      "title": "Break Text Into Ordered Word Chunks",
      "topics": [
        "split_portion"
      ]
    },
    {
      "page": "split_run",
      "title": "Split Runs",
      "topics": [
        "split_run",
        "split_run.data.frame",
        "split_run.default"
      ]
    },
    {
      "page": "split_sentence",
      "title": "Split Sentences",
      "topics": [
        "split_sentence",
        "split_sentence.data.frame",
        "split_sentence.default"
      ]
    },
    {
      "page": "split_sentence_token",
      "title": "Split Sentences & Tokens",
      "topics": [
        "split_sentence_token",
        "split_sentence_token.data.frame",
        "split_sentence_token.default"
      ]
    },
    {
      "page": "split_speaker",
      "title": "Break and Stretch if Multiple Persons per Cell",
      "topics": [
        "split_speaker"
      ]
    },
    {
      "page": "split_token",
      "title": "Split Tokens",
      "topics": [
        "split_token",
        "split_token.data.frame",
        "split_token.default"
      ]
    },
    {
      "page": "split_transcript",
      "title": "Split a Transcript Style Vector on Delimiter & Coerce to Dataframe",
      "topics": [
        "split_transcript"
      ]
    },
    {
      "page": "split_word",
      "title": "Split Words",
      "topics": [
        "split_word",
        "split_word.data.frame",
        "split_word.default"
      ]
    },
    {
      "page": "textshape",
      "title": "Tools for Reshaping Text",
      "topics": [
        "package-textshape",
        "textshape"
      ]
    },
    {
      "page": "tidy_colo_dtm",
      "title": "Convert a 'DocumentTermMatrix'/'TermDocumentMatrix' into Collocating Words in Tidy Form",
      "topics": [
        "tidy_colo_dtm",
        "tidy_colo_tdm"
      ]
    },
    {
      "page": "tidy_dtm",
      "title": "Convert a 'DocumentTermMatrix'/'TermDocumentMatrix' into Tidy Form",
      "topics": [
        "tidy_dtm",
        "tidy_tdm"
      ]
    },
    {
      "page": "tidy_list",
      "title": "Tidy a List of Named Dataframes or Named Vectors or Vectors",
      "topics": [
        "tidy_list"
      ]
    },
    {
      "page": "tidy_matrix",
      "title": "Convert a Matrix into Tidy Form",
      "topics": [
        "tidy_adjacency_matrix",
        "tidy_matrix"
      ]
    },
    {
      "page": "tidy_table",
      "title": "Tidy a Table: Bind Its Values with Its Names",
      "topics": [
        "tidy_table"
      ]
    },
    {
      "page": "tidy_vector",
      "title": "Tidy a Named Atomic Vector: Bind Its Values with Its Names",
      "topics": [
        "tidy_vector"
      ]
    },
    {
      "page": "unique_pairs",
      "title": "Extract Only Unique Pairs of Collocating Words in 'tidy_colo_dtm'",
      "topics": [
        "unique_pairs",
        "unique_pairs.data.table",
        "unique_pairs.default"
      ]
    },
    {
      "page": "unnest_text",
      "title": "Un-nest Nested Text Columns",
      "topics": [
        "unnest_text"
      ]
    }
  ],
  "_readme": "https://github.com/trinker/textshape/raw/HEAD/README.md",
  "_rundeps": [
    "data.table",
    "slam",
    "stringi"
  ],
  "_score": 8.99007361971137,
  "_indexed": true,
  "_nocasepkg": "textshape",
  "_universes": [
    "trinker"
  ],
  "_binaries": [
    {
      "r": "4.7.0",
      "os": "linux",
      "version": "1.7.6",
      "date": "2026-07-02T08:43:38.000Z",
      "distro": "resolute",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/047297849c24d143cb924984be7d77eb4476f257b11ee8d500e8322d09802219",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.6.1",
      "os": "linux",
      "version": "1.7.6",
      "date": "2026-07-02T08:43:49.000Z",
      "distro": "resolute",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/7b3191447f54575d124d78549421727f2171c9e012724d26a474272fab4590ea",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.5.3",
      "os": "mac",
      "version": "1.7.6",
      "date": "2026-07-02T08:43:31.000Z",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/d15fdc917a4113f17cc784a5bfd6af25ad4aa5f9917e3cab78fadec8017367d5",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.6.1",
      "os": "mac",
      "version": "1.7.6",
      "date": "2026-07-02T08:43:05.000Z",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/0a7d08694da02412aba39c06a33f195c03b125c985cf80cbd7463b5e13f89b10",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.6.0",
      "os": "wasm",
      "version": "1.7.6",
      "date": "2026-07-02T08:43:37.000Z",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/2cd6ce43013f6e0a3c617c90b485e2902f8e4c062bfe2e1dcabfa0f47ab84dfe",
      "status": "success",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.7.0",
      "os": "win",
      "version": "1.7.6",
      "date": "2026-07-02T08:42:50.000Z",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/5ba5786210dbc22322b2232b309e2656c69255d42c98edd702bb55488cda43b1",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.5.3",
      "os": "win",
      "version": "1.7.6",
      "date": "2026-07-02T08:43:08.000Z",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/f905d92b06d426d1f6802a8397788959f00ef7e5702191aea4c382b78d04e9f9",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    },
    {
      "r": "4.6.1",
      "os": "win",
      "version": "1.7.6",
      "date": "2026-07-02T08:42:59.000Z",
      "commit": "61dc5f1e0ba817571d97d87751959f78613ad92c",
      "fileid": "https://r2.ropensci.org/26dd8c915289a73e94ceac2e1562227cb709b2a48701853102eba00d05cc5921",
      "status": "success",
      "check": "OK",
      "buildurl": "https://github.com/r-universe/trinker/actions/runs/28576955206"
    }
  ]
}