PHPackages                             artarts36/str - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. artarts36/str

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

artarts36/str
=============

String Wrapper

2.7.0(2y ago)24.0k↓73.3%5MITPHPPHP &gt;=7.3

Since Aug 22Pushed 2y ago1 watchersCompare

[ Source](https://github.com/ArtARTs36/str)[ Packagist](https://packagist.org/packages/artarts36/str)[ RSS](/packages/artarts36-str/feed)WikiDiscussions 2.x Synced yesterday

READMEChangelog (10)Dependencies (4)Versions (60)Used By (5)

Str
---

[](#str)

[![PHP Composer](https://github.com/ArtARTs36/str/workflows/Testing/badge.svg?branch=master)](https://github.com/ArtARTs36/str/workflows/Testing/badge.svg?branch=master)[![License: MIT](https://camo.githubusercontent.com/fdf2982b9f5d7489dcf44570e714e3a15fce6253e0cc6b5aa61a075aac2ff71b/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f4c6963656e73652d4d49542d79656c6c6f772e737667)](https://opensource.org/licenses/MIT)[![Total Downloads](https://camo.githubusercontent.com/66135b51970c6064003d686217b5d4cda3051f4a2c35028415435349c764284d/68747470733a2f2f706f7365722e707567782e6f72672f6172746172747333362f7374722f642f746f74616c2e737667)](https://poser.pugx.org/artarts36/str/d/total.svg)

This package provides string wrapper for PHP.

---

### Installation:

[](#installation)

Run `composer require artarts36/str`

---

### Str::chars():

[](#strchars)

```
use ArtARTs36\Str\Str;

var_dump(Str::make("Водка")->chars());
//array(5) {
//  [0] =>
//  string(2) "В"
//  [1] =>
//  string(2) "о"
//  [2] =>
//  string(2) "д"
//  [3] =>
//  string(2) "к"
//  [4] =>
//  string(2) "а"
//}
```

---

### Str::count():

[](#strcount)

```
use ArtARTs36\Str\Str;

var_dump(Str::make("test")->count()); // 4
```

---

### Str::toLower():

[](#strtolower)

```
use ArtARTs36\Str\Str;

var_dump(Str::make("Test")->toLower()); // test
```

---

### Str::positions():

[](#strpositions)

```
use ArtARTs36\Str\Str;

$string = 'Hello Hello Hello Artem Hello Artem Hello Artem Artem';
$str = Str::make($string);

var_dump($str->positions('artem', true)); // [18, 30, 42, 48]
var_dump($str->positions('Hello')); // [0, 6, 12, 24, 36]
```

---

### Str::reverse():

[](#strreverse)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Artem')->reverse()); // metrA
```

---

### Str::append():

[](#strappend)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Hello')->append('Artem', ' ')); // Hello Artem
```

---

### Str::prepend():

[](#strprepend)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Dev')->prepend('Hello', ' ')); // Hello Dev
```

---

### Str::equals

[](#strequals)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Dev')->equals('dev')); // false
var_dump(Str::make('Dev')->equals('Dev')); // true
```

---

### Str::deleteLastSymbol

[](#strdeletelastsymbol)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Dev')->deleteLastSymbol()); // De
```

---

### Str::deleteFirstSymbol

[](#strdeletefirstsymbol)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Dev')->deleteFirstSymbol()); // ev
```

---

### Str::delete

[](#strdelete)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Test A B')->delete(['Test', 'A'])); // "  B"
var_dump(Str::make('Test A B')->delete(['Test', 'A'], true)); // "B"
```

---

### Str::trim

[](#strtrim)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('  TEST ')->trim()); // "TEST"
```

---

### Iterable

[](#iterable)

```
use ArtARTs36\Str\Str;

foreach (Str::make('test') as $char) {
    var_dump($char);
}
// t
// e
// s
// t
```

---

### Str::words

[](#strwords)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('TEST 123')->words()); // ['TEST', '123']
```

---

### Str::isEmpty()

[](#strisempty)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('TEST 123')->isEmpty()); // false
var_dump(Str::make(' ')->isEmpty()); // true
```

---

### Str::usingLetters()

[](#strusingletters)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('AABBBCCC')->usingLetters());
// [A, B, C]
```

---

### Str::getLettersStat()

[](#strgetlettersstat)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('AABBBCCC')->getLettersStat()->getDict());
// [A => 2, B => 3, C => 3]
```

---

### Str::upWords()

[](#strupwords)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello dev')->upWords());
// "Hello Dev"
```

---

### Str::explode()

[](#strexplode)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->explode('.'));
// ['Hello', 'Dev']
```

---

### Str::sortByChars()

[](#strsortbychars)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('ABCD')->sortByChars());
// CDBA
```

---

### Str::sortByWordsLengths()

[](#strsortbywordslengths)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('BBB A DDDDD CCCC')->sortByWordsLengths());
// A BBB CCCC DDDDD
```

---

### Str::upFirstSymbol()

[](#strupfirstsymbol)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('слово')->upFirstSymbol());
// "Слово"
```

---

### Str::sentences()

[](#strsentences)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->sentences());
// ['hello', 'dev']
```

---

### Str::containsAny()

[](#strcontainsany)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->containsAny([
    'dev',
]));
// true
```

---

### Str::containsAll()

[](#strcontainsall)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->containsAll([
    'dev',
    'hello',
]));
// true
```

---

### Str::random()

[](#strrandom)

```
use ArtARTs36\Str\Str;

var_dump(Str::random());
// random string
```

---

### Str::randomFix()

[](#strrandomfix)

```
use ArtARTs36\Str\Str;

var_dump(Str::randomFix(12));
// random string 12 length
```

---

### Str::shuffle()

[](#strshuffle)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Hello')->shuffle());
```

---

### Str::getBytes()

[](#strgetbytes)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->getBytes());
// [72, 101, 108, 108, 111]
```

---

### Str::startsWith()

[](#strstartswith)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->startsWith('hello'));
// true
```

---

### Str::endsWith()

[](#strendswith)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('hello.dev')->endsWith('dev'));
// true
```

---

### Str::hashCode()

[](#strhashcode)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Hello')->hashCode());
// 69609650
```

---

### Str::isDigit()

[](#strisdigit)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('123')->isDigit());
// true
```

---

### Str::resize()

[](#strresize)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Test')->resize(5));
// 0Test
```

---

### Str::swapCase()

[](#strswapcase)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Test')->swapCase());
// tEST
```

### Str::hasUppercaseSymbols()

[](#strhasuppercasesymbols)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Artem')->hasUppercaseSymbols()); // true
var_dump(Str::make('artem')->hasUppercaseSymbols()); // false
```

### Str::hasLowercaseSymbols()

[](#strhaslowercasesymbols)

```
use ArtARTs36\Str\Str;

var_dump(Str::make('Artem')->hasLowercaseSymbols()); // true
var_dump(Str::make('ARTEM')->hasLowercaseSymbols()); // false
```

###  Health Score

33

—

LowBetter than 72% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity24

Limited adoption so far

Community13

Small or concentrated contributor base

Maturity64

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~20 days

Recently: every ~28 days

Total

56

Last Release

1024d ago

Major Versions

1.x-dev → 2.0.02021-08-21

PHP version history (2 changes)1.0.0PHP &gt;=7.2

2.5.0PHP &gt;=7.3

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/8027278?v=4)[Artem Ukrainskii](/maintainers/ArtARTs36)[@ArtARTs36](https://github.com/ArtARTs36)

---

Top Contributors

[![ArtARTs36](https://avatars.githubusercontent.com/u/8027278?v=4)](https://github.com/ArtARTs36 "ArtARTs36 (111 commits)")

###  Code Quality

TestsPHPUnit

Static AnalysisPHPStan

Code StylePHP CS Fixer

Type Coverage Yes

### Embed Badge

![Health badge](/badges/artarts36-str/health.svg)

```
[![Health](https://phpackages.com/badges/artarts36-str/health.svg)](https://phpackages.com/packages/artarts36-str)
```

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
