Compare commits

...

9 Commits

  1. 3
      ideal-flatmate-manchester.org
  2. 10
      renders/2024-02-29-roomies-rent-manc.html
  3. BIN
      renders/2024-02-29-roomies-rent-manc.png
  4. 2
      renders/manc-rent-averages-feb-2024.html
  5. BIN
      renders/manc-rent-averages-feb-2024.png
  6. 296
      roomies-manchester.org
  7. 19
      summary-manchester.org
  8. 25
      working-data/2024-02-29-roomies-manc.csv
  9. 1
      working-data/manc-avg-rent-feb-2024.csv

3
ideal-flatmate-manchester.org

@ -86,9 +86,6 @@ wrong listings.
** Create CSV of Listings
Need to come back to this and finish it off. Left it in a mess because it's the
end of the day (at time of commit) and need to get some sleep.
#+begin_src lisp :results output raw
(let ((filepath #P"working-data/2024-02-24-ideal-flatmate-manc.csv"))
(with-open-file (out-stream

10
renders/2024-02-29-roomies-rent-manc.html

@ -0,0 +1,10 @@
<html><head><style>html{
height: 100%;
}
html body{
height: 100%;
display: flex;
justify-content: center;
align-items: center;
}</style><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega@5'></script><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega-lite@5'></script><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega-embed@6'></script></head><body><div id='vis'></div><script>var spec = {"data":{"values":[{"rowId":23,"location":"Manchester England","rent":650,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/489135"},{"rowId":22,"location":"Manchester England","rent":575,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/354296"},{"rowId":21,"location":"Manchester England","rent":475,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/361541"},{"rowId":19,"location":"Manchester England","rent":600,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/396587"},{"rowId":18,"location":"Talbot Road Manchester England","rent":450,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/267267"},{"rowId":16,"location":"Stockdale Road Manchester England","rent":750,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/344733"},{"rowId":15,"location":"Yates Street Rhodes England","rent":430,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/393284"},{"rowId":14,"location":"Manchester England","rent":580,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/434137"},{"rowId":13,"location":"Manchester England","rent":1000,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/406205"},{"rowId":11,"location":"Briarfield Road Manchester England","rent":700,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/328052"},{"rowId":8,"location":"Old Trafford England","rent":600,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/439451"},{"rowId":7,"location":"Manchester England","rent":600,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/476586"},{"rowId":5,"location":"Beswick Street Manchester England","rent":750,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/481551"},{"rowId":3,"location":"Manchester Road Denton England","rent":400,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/484296"},{"rowId":2,"location":"Openshaw Walk Manchester England","rent":700,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/392849"},{"rowId":0,"location":"Nobel Way Manchester England","rent":1000,"billsInc":"Yes","url":"https://www.roomies.co.uk/rooms/502205"}]},"$schema":"https://vega.github.io/schema/vega-lite/v5.json","title":"Rent Rates for Manchester on Roomies (29/02/2024)","width":600,"height":600,"layer":[{"mark":{"type":"bar"},"encoding":{"x":{"field":"rowId","title":"Assigned Id.","type":"nominal","axis":{"labelAngle":0}},"y":{"field":"rent","title":"Monthly Rent with Bills Inc. (£)","type":"quantitative"},"tooltip":{"field":"rent"}}},{"mark":{"type":"rule","color":"darkorange","size":3},"encoding":{"y":{"field":"rent","type":"quantitative","aggregate":"average"},"tooltip":{"field":"rent","type":"quantitative","aggregate":"average"}}}]}; vegaEmbed("#vis", spec).then(result => console.log(result)).catch(console.warn);</script></body></html>

BIN
renders/2024-02-29-roomies-rent-manc.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 43 KiB

2
renders/manc-rent-averages-feb-2024.html

@ -7,4 +7,4 @@ html body{
display: flex;
justify-content: center;
align-items: center;
}</style><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega@5'></script><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega-lite@5'></script><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega-embed@6'></script></head><body><div id='vis'></div><script>var spec = {"data":{"values":[{"xAxis":"Ideal Flatmate","yAxis":714},{"xAxis":"Spare Room","yAxis":589},{"xAxis":"Right Move","yAxis":1204}]},"$schema":"https://vega.github.io/schema/vega-lite/v5.json","title":"Average Rent Rates Manchester Feb. 2024","mark":"bar","width":600,"height":600,"encoding":{"x":{"field":"xAxis","title":"Company","type":"nominal","axis":{"labelAngle":0}},"y":{"field":"yAxis","title":"Rent Average (£)","type":"quantitative"},"tooltip":{"field":"yAxis"}}}; vegaEmbed("#vis", spec).then(result => console.log(result)).catch(console.warn);</script></body></html>
}</style><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega@5'></script><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega-lite@5'></script><script type='text/javascript' src='https://cdn.jsdelivr.net/npm/vega-embed@6'></script></head><body><div id='vis'></div><script>var spec = {"data":{"values":[{"xAxis":"Roomies","yAxis":641},{"xAxis":"Ideal Flatmate","yAxis":714},{"xAxis":"Spare Room","yAxis":589},{"xAxis":"Right Move","yAxis":1204}]},"$schema":"https://vega.github.io/schema/vega-lite/v5.json","title":"Monthly Average Rent Rates (Bills Inc.) Manchester Feb. 2024","mark":"bar","width":600,"height":600,"encoding":{"x":{"field":"xAxis","title":"Company","type":"nominal","axis":{"labelAngle":0}},"y":{"field":"yAxis","title":"Rent (£)","type":"quantitative"},"tooltip":{"field":"yAxis"}}}; vegaEmbed("#vis", spec).then(result => console.log(result)).catch(console.warn);</script></body></html>

BIN
renders/manc-rent-averages-feb-2024.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 35 KiB

After

Width:  |  Height:  |  Size: 37 KiB

296
roomies-manchester.org

@ -12,6 +12,24 @@
#+creator: Emacs 29.1.90 (Org mode 9.7-pre)
#+cite_export:
* Setup Common Lisp Environment
I’ve copied the following code block over from other files. Run it if this is
your first file open in the session.
#+begin_src lisp :session :results silent
(ql:quickload :com.inuoe.jzon) ; JSON parser.
(ql:quickload :dexador) ; HTTP requests.
(ql:quickload :plump) ; HTML/XML parser.
(ql:quickload :lquery) ; HTML/DOM manipulation.
(ql:quickload :lparallel) ; Parallel programming.
(ql:quickload :cl-ppcre) ; RegEx. library.
(ql:quickload :plot/vega) ; Vega plotting library.
(ql:quickload :lisp-stat) ; Stat's library.
(ql:quickload :data-frame) ; Data frame library eqv. to Python's Numpy.
(ql:quickload :str) ; String library, expands on 'string' library.
#+end_src
* Gather Roomie Data (Manually)
- [[https://www.roomies.co.uk/][Roomies]]
@ -25,29 +43,275 @@ instead. The search filters I used:
- Date: 2024-02-29
- Location: Manchester
- Price Range: £0–1200
- Payment Frequency: Month
There are only twenty-three listings. I’ve stored the HTML is
=raw-data/external/2024-02-29_roomies-manc/=. As is standard behaviour at this
point, I won’t be committing that data to the repositories commit history.
* Setup Common Lisp Environment
* Clean Up and Parse Data
I’ve copied the following code block over from other files. Run it if this is
your first file open in the session.
I'm applying the same tactic as the previous website reviews. I've separated the
listings into their own files, reducing the chance of attaching the wrong data
to the wrong listings in the CSV files (after parsing the HTML files).
#+begin_src lisp :session :results silent
(ql:quickload :com.inuoe.jzon) ; JSON parser.
(ql:quickload :dexador) ; HTTP requests.
(ql:quickload :plump) ; HTML/XML parser.
(ql:quickload :lquery) ; HTML/DOM manipulation.
(ql:quickload :lparallel) ; Parallel programming.
(ql:quickload :cl-ppcre) ; RegEx. library.
(ql:quickload :plot/vega) ; Vega plotting library.
(ql:quickload :lisp-stat) ; Stat's library.
(ql:quickload :data-frame) ; Data frame library eqv. to Python's Numpy.
(ql:quickload :str) ; String library, expands on 'string' library.
#+begin_src shell :results silent
mkdir raw-data/external/2024-02-29_roomies-manc-listings/
#+end_src
#+begin_src lisp :results silent
(let ((counter 0))
(loop for file-path
in (directory #P"raw-data/external/2024-02-29_roomies-manc/*.html")
do (with-open-file (in-stream file-path)
(let* ((doc (plump:parse in-stream))
(listings (lquery:$ doc ".tile" (serialize))))
(loop for item across listings
do (let ((out-path
(merge-pathnames
#P"raw-data/external/2024-02-29_roomies-manc-listings/"
(format nil "listing-~a.html" (write-to-string counter)))))
(with-open-file (out-stream
out-path
:direction :output
:if-exists :supersede)
(format out-stream "~a" item))
(incf counter)))))))
#+end_src
** Create CSV Listings
#+begin_src lisp :results output raw
;; There is a lot of cleaning of text as the function goes along in this
;; one. The best I can say is take your time when making your way through the
;; code. Essentially, the function has to grab the text, convert it into a text
;; format the code can work with and then strip/replace tokens within the text
;; to make it readable in the CSV file. Yes, this is not my best work, but it
;; works and I don't intend to run this in production for years on end. Get the
;; data, parse it and get out.
(let ((filepath #P"working-data/2024-02-29-roomies-manc.csv"))
(with-open-file (out-stream
filepath
:direction :output
:if-exists :supersede)
(let ((row-id 0))
(format out-stream "ROW-ID,LOCATION,RENT,BILLS-INC,URL~%")
(loop for file-path
in (directory #P"raw-data/external/2024-02-29_roomies-manc-listings/*.html")
do (with-open-file (in-stream file-path)
(let* ((doc (plump:parse in-stream))
(listing (lquery:$ doc ".tile" (text)))
(price (lquery:$ doc ".text-white" (text)))
(cleaned-price
(cl-ppcre:regex-replace-all
"[\\s\\n]+"
(format nil
(str:replace-all
"," ""
(format nil "~s" (aref price 0))))
" "))
(just-price (format nil "~a"
(first (cl-ppcre:all-matches-as-strings
"\\d+" cleaned-price))))
(bills (format nil "~a"
(first (cl-ppcre:all-matches-as-strings
"inc." cleaned-price))))
(location (lquery:$ doc ".text-lg" (text)))
(cleaned-loc
(cl-ppcre:regex-replace-all
"[\\s\\n]+" (format nil "~a" (aref location 0)) " "))
(link (lquery:$ doc "a" (attr :href))))
(format out-stream "~d,~a,~d,~a,~a~%"
row-id
(string-trim " "
(str:replace-all "," " " cleaned-loc))
just-price
(if (string= "inc." bills)
(format nil "Yes")
(format nil "No"))
(aref link 0)))
(incf row-id)))))
(format t "[[file:./~a]]" filepath))
#+end_src
* TODO Clean Up and Parse Data
#+RESULTS:
[[file:./working-data/2024-02-29-roomies-manc.csv]]
The code above produced a CSV file with a few ~NIL~ results in the ~RENT~
column. These listings are either 'featured' or a 'verified account'. Because
the numbers are so small, I've updated them manually.
* Explore CSV Data for Roomies (2024-02-29)
#+begin_src lisp :session
(lisp-stat:defdf *room-manc*
(lisp-stat:read-csv #P"working-data/2024-02-29-roomies-manc.csv"))
#+end_src
#+RESULTS:
: #<DATA-FRAME:DATA-FRAME (24 observations of 5 variables)>
Because the number of listing are so small, compared to [[file:./right-move-manchester.org][Right Move]] and [[file:./spare-room-manchester.org][Spare
Room]] (both Manc.) listings, I can output the data here.
#+begin_src lisp :session :results output drawer
(lisp-stat:print-markdown *room-manc*)
#+end_src
#+RESULTS:
:results:
| ROW-ID | LOCATION | RENT | BILLS-INC | URL |
|--------+------------------------------------------+------+-----------+----------------------------------------|
| 0 | Nobel Way Manchester England | 1000 | Yes | https://www.roomies.co.uk/rooms/502205 |
| 1 | Audenshaw England | 700 | No | https://www.roomies.co.uk/rooms/504567 |
| 2 | Openshaw Walk Manchester England | 700 | Yes | https://www.roomies.co.uk/rooms/392849 |
| 3 | Manchester Road Denton England | 400 | Yes | https://www.roomies.co.uk/rooms/484296 |
| 4 | Manchester Street Old Trafford England | 750 | No | https://www.roomies.co.uk/rooms/484350 |
| 5 | Beswick Street Manchester England | 750 | Yes | https://www.roomies.co.uk/rooms/481551 |
| 6 | Mealhouse Lane Atherton England | 650 | No | https://www.roomies.co.uk/rooms/476315 |
| 7 | Manchester England | 600 | Yes | https://www.roomies.co.uk/rooms/476586 |
| 8 | Old Trafford England | 600 | Yes | https://www.roomies.co.uk/rooms/439451 |
| 9 | Droylsden Road Manchester England | 550 | No | https://www.roomies.co.uk/rooms/457342 |
| 10 | Audenshaw England | 550 | No | https://www.roomies.co.uk/rooms/453458 |
| 11 | Briarfield Road Manchester England | 700 | Yes | https://www.roomies.co.uk/rooms/328052 |
| 12 | Manchester England | 700 | No | https://www.roomies.co.uk/rooms/472435 |
| 13 | Manchester England | 1000 | Yes | https://www.roomies.co.uk/rooms/406205 |
| 14 | Manchester England | 580 | Yes | https://www.roomies.co.uk/rooms/434137 |
| 15 | Yates Street Rhodes England | 430 | Yes | https://www.roomies.co.uk/rooms/393284 |
| 16 | Stockdale Road Manchester England | 750 | Yes | https://www.roomies.co.uk/rooms/344733 |
| 17 | Manchester England | 800 | No | https://www.roomies.co.uk/rooms/472436 |
| 18 | Talbot Road Manchester England | 450 | Yes | https://www.roomies.co.uk/rooms/267267 |
| 19 | Manchester England | 600 | Yes | https://www.roomies.co.uk/rooms/396587 |
| 20 | Chelsfield Grove Manchester England | 550 | No | https://www.roomies.co.uk/rooms/499082 |
| 21 | Manchester England | 475 | Yes | https://www.roomies.co.uk/rooms/361541 |
| 22 | Manchester England | 575 | Yes | https://www.roomies.co.uk/rooms/354296 |
| 23 | Manchester England | 650 | Yes | https://www.roomies.co.uk/rooms/489135 |
:end:
I've assumed the position of excluding the listings which don't include bills in
the rent advertised. So, I'm need to create a new data-frame, which filters out
the listings which don't include bills.
#+begin_src lisp :session
(lisp-stat:defdf *room-manc-filt*
(lisp-stat:filter-rows *room-manc* '(string= "Yes" bills-inc)))
#+end_src
#+RESULTS:
: #<DATA-FRAME:DATA-FRAME (16 observations of 5 variables)>
The data with just the listings which include bills in the rent.
#+begin_src lisp :session :results output drawer
(lisp-stat:print-markdown *room-manc-filt*)
#+end_src
#+RESULTS:
:results:
| ROW-ID | LOCATION | RENT | BILLS-INC | URL |
|--------+--------------------------------------+------+-----------+----------------------------------------|
| 0 | Nobel Way Manchester England | 1000 | Yes | https://www.roomies.co.uk/rooms/502205 |
| 2 | Openshaw Walk Manchester England | 700 | Yes | https://www.roomies.co.uk/rooms/392849 |
| 3 | Manchester Road Denton England | 400 | Yes | https://www.roomies.co.uk/rooms/484296 |
| 5 | Beswick Street Manchester England | 750 | Yes | https://www.roomies.co.uk/rooms/481551 |
| 7 | Manchester England | 600 | Yes | https://www.roomies.co.uk/rooms/476586 |
| 8 | Old Trafford England | 600 | Yes | https://www.roomies.co.uk/rooms/439451 |
| 11 | Briarfield Road Manchester England | 700 | Yes | https://www.roomies.co.uk/rooms/328052 |
| 13 | Manchester England | 1000 | Yes | https://www.roomies.co.uk/rooms/406205 |
| 14 | Manchester England | 580 | Yes | https://www.roomies.co.uk/rooms/434137 |
| 15 | Yates Street Rhodes England | 430 | Yes | https://www.roomies.co.uk/rooms/393284 |
| 16 | Stockdale Road Manchester England | 750 | Yes | https://www.roomies.co.uk/rooms/344733 |
| 18 | Talbot Road Manchester England | 450 | Yes | https://www.roomies.co.uk/rooms/267267 |
| 19 | Manchester England | 600 | Yes | https://www.roomies.co.uk/rooms/396587 |
| 21 | Manchester England | 475 | Yes | https://www.roomies.co.uk/rooms/361541 |
| 22 | Manchester England | 575 | Yes | https://www.roomies.co.uk/rooms/354296 |
| 23 | Manchester England | 650 | Yes | https://www.roomies.co.uk/rooms/489135 |
:end:
#+begin_src lisp :session :results file
(vega:defplot roomie-monthly-manc
`(:title "Rent Rates for Manchester on Roomies (29/02/2024)"
:width 600
:height 600
:data ,*room-manc-filt*
:layer #((:mark (:type :bar)
:encoding (:x (:field :row-id :title "Assigned Id." :type :nominal :axis ("labelAngle" 0))
:y (:field :rent :title "Monthly Rent with Bills Inc. (£)" :type :quantitative)
:tooltip (:field :rent)))
(:mark (:type rule :color "darkorange" :size 3)
:encoding (:y (:field :rent :type :quantitative :aggregate :average)
:tooltip (:field :rent :type :quantitative :aggregate :average))))))
(vega:write-html roomie-monthly-manc "renders/2024-02-29-roomies-rent-manc.html")
#+end_src
#+RESULTS:
[[file:renders/2024-02-29-roomies-rent-manc.html]]
[[file:./renders/2024-02-29-roomies-rent-manc.png]]
#+begin_src lisp :session :results output code raw
(format t "- Mean Rent: £ ~a~%" (float (lisp-stat:mean *room-manc-filt*:rent)))
(format t "- Min. Rent: £ ~d~%" (reduce #'min *room-manc-filt*:rent))
(format t "- Max. Rent: £ ~d" (reduce #'max *room-manc-filt*:rent))
#+end_src
#+RESULTS:
- Mean Rent: £ 641.25
- Min. Rent: £ 400
- Max. Rent: £ 1000
* Summary of Roomies Data
#+begin_src calc :results output
641.25 * 12
#+end_src
#+RESULTS:
: 7695
Based on the average rent (inc. bills) for Roomies, I would need to make around
£8,000/yr. to cover my living expenses. This does not include, travel, food,
clothing, socialising or income tax payments. In the other Manchester reviews,
I've been adding £5,000 on top of the basic rent total. This is so I have a
minimum threshold for money I need to make to cover my costs (i.e. to
survive). So, adding the £5,000 on top…
#+begin_src calc :results output
7695 + 5000
#+end_src
#+RESULTS:
: 12695
Using £12695 as the starting point (see [[file:./uk-wage-tax.org][UK Wage and Tax Rates]]),
#+begin_src lisp :results output raw
(let* ((earning-target 12695)
(p-allow 12570)
(taxable-income (- earning-target p-allow))
(tax-to-pay (* taxable-income 0.8))
(total (- earning-target tax-to-pay)))
(format t "- Annual Target Salary: £~a~%" earning-target)
(format t "- Part of Salary which is Taxable: £~a~%" taxable-income)
(format t "- Tax to Pay: £~a~%" tax-to-pay)
(format t "- Salary After Tax: £~a~%" total))
#+end_src
#+RESULTS:
- Annual Target Salary: £12695
- Part of Salary which is Taxable: £125
- Tax to Pay: £100.0
- Salary After Tax: £12595.0
| Time Span | Value After Tax (£) | Mean Rent (£) |
|-----------------------+---------------------+---------------|
| Annually | 12595 | 641.25 |
| Monthly (Before Rent) | 1049.5833 | |
| Monthly (After Rent) | 408.3333 | |
| Weekly (After Rent) | 102.08333 | |
| Daily (After Rent) | 14.583333 | |
#+TBLFM: @3$2=@-1/12::@4$2=@-1-@-2$+1::@5$2=@-1/4::@6$2=@-1/7
This bit I need to start work on.
The spending limit of £14.58/day falls inline with the other Manchester-based
files. Not great but these figures represent the minimum I need to aim for,
regarding wages/salaries.

19
summary-manchester.org

@ -53,6 +53,7 @@ this up would take to long, for little gain.
| Right Move | 121 | 1204 | £275–£1500 | 945 | 1495 |
| Spare Room | 647 | 589 | £100–£1260 | 300 | 1260 |
| Ideal Flatmate | 17 | 714 | £200–£1200 | 480 | 956 |
| Roomies | 16 | 641 | £0–£1200 | 400 | 1000 |
| | | | | | |
#+begin_src lisp :var table=manc-avg-rent :results output raw
@ -74,16 +75,16 @@ this up would take to long, for little gain.
[[file:working-data/manc-avg-rent-feb-2024.csv]]
#+begin_src lisp :results file
(let* ((values (lisp-stat:plist-df `(:x-axis #("Right Move" "Spare Room" "Ideal Flatmate")
:y-axis #(1204 589 714)))))
(let* ((values (lisp-stat:plist-df `(:x-axis #("Right Move" "Spare Room" "Ideal Flatmate" "Roomies")
:y-axis #(1204 589 714 641)))))
(vega:defplot manc-avg-rent
`(:title "Average Rent Rates Manchester Feb. 2024"
`(:title "Monthly Average Rent Rates (Bills Inc.) Manchester Feb. 2024"
:mark :bar
:width 600
:height 600
:data ,values
:encoding (:x (:field :x-axis :title "Company" :type :nominal :axis ("labelAngle" 0))
:y (:field :y-axis :title "Rent Average (£)" :type :quantitative)
:y (:field :y-axis :title "Rent (£)" :type :quantitative)
:tooltip (:field :y-axis))))
(vega:write-html manc-avg-rent "renders/manc-rent-averages-feb-2024.html"))
#+end_src
@ -91,4 +92,14 @@ this up would take to long, for little gain.
#+RESULTS:
[[file:renders/manc-rent-averages-feb-2024.html]]
To save time, copying and pasting over the PNG file, just run this. Make sure
the HTML version of the chart saves the exported PNG file to your =~/Downloads/=
directory.
#+begin_src shell
mv ~/Downloads/visualization.png ./renders/manc-rent-averages-feb-2024.png
#+end_src
#+RESULTS:
[[file:./renders/manc-rent-averages-feb-2024.png]]

25
working-data/2024-02-29-roomies-manc.csv

@ -0,0 +1,25 @@
ROW-ID,LOCATION,RENT,BILLS-INC,URL
0,Nobel Way Manchester England,1000,Yes,https://www.roomies.co.uk/rooms/502205
1,Audenshaw England,700,No,https://www.roomies.co.uk/rooms/504567
2,Openshaw Walk Manchester England,700,Yes,https://www.roomies.co.uk/rooms/392849
3,Manchester Road Denton England,400,Yes,https://www.roomies.co.uk/rooms/484296
4,Manchester Street Old Trafford England,750,No,https://www.roomies.co.uk/rooms/484350
5,Beswick Street Manchester England,750,Yes,https://www.roomies.co.uk/rooms/481551
6,Mealhouse Lane Atherton England,650,No,https://www.roomies.co.uk/rooms/476315
7,Manchester England,600,Yes,https://www.roomies.co.uk/rooms/476586
8,Old Trafford England,600,Yes,https://www.roomies.co.uk/rooms/439451
9,Droylsden Road Manchester England,550,No,https://www.roomies.co.uk/rooms/457342
10,Audenshaw England,550,No,https://www.roomies.co.uk/rooms/453458
11,Briarfield Road Manchester England,700,Yes,https://www.roomies.co.uk/rooms/328052
12,Manchester England,700,No,https://www.roomies.co.uk/rooms/472435
13,Manchester England,1000,Yes,https://www.roomies.co.uk/rooms/406205
14,Manchester England,580,Yes,https://www.roomies.co.uk/rooms/434137
15,Yates Street Rhodes England,430,Yes,https://www.roomies.co.uk/rooms/393284
16,Stockdale Road Manchester England,750,Yes,https://www.roomies.co.uk/rooms/344733
17,Manchester England,800,No,https://www.roomies.co.uk/rooms/472436
18,Talbot Road Manchester England,450,Yes,https://www.roomies.co.uk/rooms/267267
19,Manchester England,600,Yes,https://www.roomies.co.uk/rooms/396587
20,Chelsfield Grove Manchester England,550,No,https://www.roomies.co.uk/rooms/499082
21,Manchester England,475,Yes,https://www.roomies.co.uk/rooms/361541
22,Manchester England,575,Yes,https://www.roomies.co.uk/rooms/354296
23,Manchester England,650,Yes,https://www.roomies.co.uk/rooms/489135
1 ROW-ID LOCATION RENT BILLS-INC URL
2 0 Nobel Way Manchester England 1000 Yes https://www.roomies.co.uk/rooms/502205
3 1 Audenshaw England 700 No https://www.roomies.co.uk/rooms/504567
4 2 Openshaw Walk Manchester England 700 Yes https://www.roomies.co.uk/rooms/392849
5 3 Manchester Road Denton England 400 Yes https://www.roomies.co.uk/rooms/484296
6 4 Manchester Street Old Trafford England 750 No https://www.roomies.co.uk/rooms/484350
7 5 Beswick Street Manchester England 750 Yes https://www.roomies.co.uk/rooms/481551
8 6 Mealhouse Lane Atherton England 650 No https://www.roomies.co.uk/rooms/476315
9 7 Manchester England 600 Yes https://www.roomies.co.uk/rooms/476586
10 8 Old Trafford England 600 Yes https://www.roomies.co.uk/rooms/439451
11 9 Droylsden Road Manchester England 550 No https://www.roomies.co.uk/rooms/457342
12 10 Audenshaw England 550 No https://www.roomies.co.uk/rooms/453458
13 11 Briarfield Road Manchester England 700 Yes https://www.roomies.co.uk/rooms/328052
14 12 Manchester England 700 No https://www.roomies.co.uk/rooms/472435
15 13 Manchester England 1000 Yes https://www.roomies.co.uk/rooms/406205
16 14 Manchester England 580 Yes https://www.roomies.co.uk/rooms/434137
17 15 Yates Street Rhodes England 430 Yes https://www.roomies.co.uk/rooms/393284
18 16 Stockdale Road Manchester England 750 Yes https://www.roomies.co.uk/rooms/344733
19 17 Manchester England 800 No https://www.roomies.co.uk/rooms/472436
20 18 Talbot Road Manchester England 450 Yes https://www.roomies.co.uk/rooms/267267
21 19 Manchester England 600 Yes https://www.roomies.co.uk/rooms/396587
22 20 Chelsfield Grove Manchester England 550 No https://www.roomies.co.uk/rooms/499082
23 21 Manchester England 475 Yes https://www.roomies.co.uk/rooms/361541
24 22 Manchester England 575 Yes https://www.roomies.co.uk/rooms/354296
25 23 Manchester England 650 Yes https://www.roomies.co.uk/rooms/489135

1
working-data/manc-avg-rent-feb-2024.csv

@ -2,4 +2,5 @@ Company,Quantity,Avg-Rent,Search-Range,Min-Rent,Max-Rent
Right Move,121,1204,£275–£1500,945,1495
Spare Room,647,589,£100–£1260,300,1260
Ideal Flatmate,17,714,£200–£1200,480,956
Roomies,16,641,£0–£1200,400,1000
,,,,,

1 Company Quantity Avg-Rent Search-Range Min-Rent Max-Rent
2 Right Move 121 1204 £275–£1500 945 1495
3 Spare Room 647 589 £100–£1260 300 1260
4 Ideal Flatmate 17 714 £200–£1200 480 956
5 Roomies 16 641 £0–£1200 400 1000
6
Loading…
Cancel
Save