ElisonSherton commited on
Commit
7eb4df4
·
1 Parent(s): 0539abd

Completed chapter 5 module 1. Loaded custom data from local disk and remote url both in huggingface datasets object

Browse files
chapter5/5-What-if-my-dataset-isn’t-on-the-Hub?.ipynb ADDED
@@ -0,0 +1,291 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "cells": [
3
+ {
4
+ "cell_type": "markdown",
5
+ "metadata": {},
6
+ "source": [
7
+ "# Load Dataset Locally\n",
8
+ "\n",
9
+ "Selecting the [SMS Spam Collection](https://archive.ics.uci.edu/dataset/228/sms+spam+collection) dataset to be loaded locally on the disk."
10
+ ]
11
+ },
12
+ {
13
+ "cell_type": "code",
14
+ "execution_count": null,
15
+ "metadata": {},
16
+ "outputs": [
17
+ {
18
+ "name": "stdout",
19
+ "output_type": "stream",
20
+ "text": [
21
+ "--2024-07-27 14:24:04-- https://archive.ics.uci.edu/static/public/228/sms+spam+collection.zip\n",
22
+ "Resolving archive.ics.uci.edu (archive.ics.uci.edu)... 128.195.10.252\n",
23
+ "Connecting to archive.ics.uci.edu (archive.ics.uci.edu)|128.195.10.252|:443... connected.\n",
24
+ "HTTP request sent, awaiting response... 200 OK\n",
25
+ "Length: unspecified\n",
26
+ "Saving to: ‘sms+spam+collection.zip’\n",
27
+ "\n",
28
+ "sms+spam+collection [ <=> ] 198.65K 252KB/s in 0.8s \n",
29
+ "\n",
30
+ "2024-07-27 14:24:07 (252 KB/s) - ‘sms+spam+collection.zip’ saved [203415]\n",
31
+ "\n"
32
+ ]
33
+ }
34
+ ],
35
+ "source": [
36
+ "!wget https://archive.ics.uci.edu/static/public/228/sms+spam+collection.zip"
37
+ ]
38
+ },
39
+ {
40
+ "cell_type": "code",
41
+ "execution_count": 2,
42
+ "metadata": {},
43
+ "outputs": [],
44
+ "source": [
45
+ "!unzip -q \"sms+spam+collection.zip\" && rm \"sms+spam+collection.zip\""
46
+ ]
47
+ },
48
+ {
49
+ "cell_type": "code",
50
+ "execution_count": 5,
51
+ "metadata": {},
52
+ "outputs": [],
53
+ "source": [
54
+ "!mv SMSSpamCollection SMSSpamCollection.txt"
55
+ ]
56
+ },
57
+ {
58
+ "cell_type": "code",
59
+ "execution_count": 6,
60
+ "metadata": {},
61
+ "outputs": [],
62
+ "source": [
63
+ "from datasets import load_dataset"
64
+ ]
65
+ },
66
+ {
67
+ "cell_type": "code",
68
+ "execution_count": 9,
69
+ "metadata": {},
70
+ "outputs": [
71
+ {
72
+ "data": {
73
+ "application/vnd.jupyter.widget-view+json": {
74
+ "model_id": "b94f7bfda8294e6e8303b067ec9c8092",
75
+ "version_major": 2,
76
+ "version_minor": 0
77
+ },
78
+ "text/plain": [
79
+ "Generating train split: 0 examples [00:00, ? examples/s]"
80
+ ]
81
+ },
82
+ "metadata": {},
83
+ "output_type": "display_data"
84
+ }
85
+ ],
86
+ "source": [
87
+ "data = load_dataset(path = \"../chapter5\", data_files = \"SMSSpamCollection.txt\")"
88
+ ]
89
+ },
90
+ {
91
+ "cell_type": "code",
92
+ "execution_count": 10,
93
+ "metadata": {},
94
+ "outputs": [
95
+ {
96
+ "data": {
97
+ "text/plain": [
98
+ "DatasetDict({\n",
99
+ " train: Dataset({\n",
100
+ " features: ['text'],\n",
101
+ " num_rows: 5574\n",
102
+ " })\n",
103
+ "})"
104
+ ]
105
+ },
106
+ "execution_count": 10,
107
+ "metadata": {},
108
+ "output_type": "execute_result"
109
+ }
110
+ ],
111
+ "source": [
112
+ "data"
113
+ ]
114
+ },
115
+ {
116
+ "cell_type": "code",
117
+ "execution_count": 15,
118
+ "metadata": {},
119
+ "outputs": [],
120
+ "source": [
121
+ "def get_feature(sample):\n",
122
+ " text = sample[\"text\"]\n",
123
+ " tokens = text.split(\"\\t\")\n",
124
+ " target = tokens[0]\n",
125
+ " sentence = \"\\t\".join(tokens[1:])\n",
126
+ " return {\"text\": sentence, \"label\": target}"
127
+ ]
128
+ },
129
+ {
130
+ "cell_type": "code",
131
+ "execution_count": 16,
132
+ "metadata": {},
133
+ "outputs": [
134
+ {
135
+ "data": {
136
+ "application/vnd.jupyter.widget-view+json": {
137
+ "model_id": "5aa833be63704697b69834e2ac2988f2",
138
+ "version_major": 2,
139
+ "version_minor": 0
140
+ },
141
+ "text/plain": [
142
+ "Map: 0%| | 0/5574 [00:00<?, ? examples/s]"
143
+ ]
144
+ },
145
+ "metadata": {},
146
+ "output_type": "display_data"
147
+ }
148
+ ],
149
+ "source": [
150
+ "new_data = data.map(get_feature)"
151
+ ]
152
+ },
153
+ {
154
+ "cell_type": "code",
155
+ "execution_count": 17,
156
+ "metadata": {},
157
+ "outputs": [
158
+ {
159
+ "data": {
160
+ "text/plain": [
161
+ "Dataset({\n",
162
+ " features: ['text', 'label'],\n",
163
+ " num_rows: 5574\n",
164
+ "})"
165
+ ]
166
+ },
167
+ "execution_count": 17,
168
+ "metadata": {},
169
+ "output_type": "execute_result"
170
+ }
171
+ ],
172
+ "source": [
173
+ "new_data[\"train\"]"
174
+ ]
175
+ },
176
+ {
177
+ "cell_type": "markdown",
178
+ "metadata": {},
179
+ "source": [
180
+ "# Load Dataset Remotely\n",
181
+ "\n",
182
+ "Load the [Gender By Name](https://archive.ics.uci.edu/dataset/591/gender+by+name) dataset remotely"
183
+ ]
184
+ },
185
+ {
186
+ "cell_type": "code",
187
+ "execution_count": 30,
188
+ "metadata": {},
189
+ "outputs": [
190
+ {
191
+ "data": {
192
+ "application/vnd.jupyter.widget-view+json": {
193
+ "model_id": "70808155f835450aa8d96f25ad2988bd",
194
+ "version_major": 2,
195
+ "version_minor": 0
196
+ },
197
+ "text/plain": [
198
+ "Downloading data: 0.00B [00:00, ?B/s]"
199
+ ]
200
+ },
201
+ "metadata": {},
202
+ "output_type": "display_data"
203
+ },
204
+ {
205
+ "data": {
206
+ "application/vnd.jupyter.widget-view+json": {
207
+ "model_id": "f4a2bd41ba2a4823a517123f60b37e0f",
208
+ "version_major": 2,
209
+ "version_minor": 0
210
+ },
211
+ "text/plain": [
212
+ "Generating train split: 0 examples [00:00, ? examples/s]"
213
+ ]
214
+ },
215
+ "metadata": {},
216
+ "output_type": "display_data"
217
+ }
218
+ ],
219
+ "source": [
220
+ "url = \"https://archive.ics.uci.edu/static/public/591/gender+by+name.zip\"\n",
221
+ "remote_data = load_dataset(\"csv\", data_files={\"train\": url})"
222
+ ]
223
+ },
224
+ {
225
+ "cell_type": "code",
226
+ "execution_count": 31,
227
+ "metadata": {},
228
+ "outputs": [
229
+ {
230
+ "data": {
231
+ "text/plain": [
232
+ "DatasetDict({\n",
233
+ " train: Dataset({\n",
234
+ " features: ['Name', 'Gender', 'Count', 'Probability'],\n",
235
+ " num_rows: 147269\n",
236
+ " })\n",
237
+ "})"
238
+ ]
239
+ },
240
+ "execution_count": 31,
241
+ "metadata": {},
242
+ "output_type": "execute_result"
243
+ }
244
+ ],
245
+ "source": [
246
+ "remote_data"
247
+ ]
248
+ },
249
+ {
250
+ "cell_type": "code",
251
+ "execution_count": 32,
252
+ "metadata": {},
253
+ "outputs": [
254
+ {
255
+ "data": {
256
+ "text/plain": [
257
+ "{'Name': 'James', 'Gender': 'M', 'Count': 5304407, 'Probability': 0.014516787}"
258
+ ]
259
+ },
260
+ "execution_count": 32,
261
+ "metadata": {},
262
+ "output_type": "execute_result"
263
+ }
264
+ ],
265
+ "source": [
266
+ "remote_data[\"train\"][0]"
267
+ ]
268
+ }
269
+ ],
270
+ "metadata": {
271
+ "kernelspec": {
272
+ "display_name": "Python 3",
273
+ "language": "python",
274
+ "name": "python3"
275
+ },
276
+ "language_info": {
277
+ "codemirror_mode": {
278
+ "name": "ipython",
279
+ "version": 3
280
+ },
281
+ "file_extension": ".py",
282
+ "mimetype": "text/x-python",
283
+ "name": "python",
284
+ "nbconvert_exporter": "python",
285
+ "pygments_lexer": "ipython3",
286
+ "version": "3.10.14"
287
+ }
288
+ },
289
+ "nbformat": 4,
290
+ "nbformat_minor": 2
291
+ }
chapter5/SMSSpamCollection.txt ADDED
The diff for this file is too large to render. See raw diff
 
chapter5/readme ADDED
@@ -0,0 +1,75 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ SMS Spam Collection v.1
2
+ -------------------------
3
+
4
+ 1. DESCRIPTION
5
+ --------------
6
+
7
+ The SMS Spam Collection v.1 (hereafter the corpus) is a set of SMS tagged messages that have been collected for SMS Spam research. It contains one set of SMS messages in English of 5,574 messages, tagged acording being ham (legitimate) or spam.
8
+
9
+ 1.1. Compilation
10
+ ----------------
11
+
12
+ This corpus has been collected from free or free for research sources at the Web:
13
+
14
+ - A collection of between 425 SMS spam messages extracted manually from the Grumbletext Web site. This is a UK forum in which cell phone users make public claims about SMS spam messages, most of them without reporting the very spam message received. The identification of the text of spam messages in the claims is a very hard and time-consuming task, and it involved carefully scanning hundreds of web pages. The Grumbletext Web site is: http://www.grumbletext.co.uk/
15
+ - A list of 450 SMS ham messages collected from Caroline Tag's PhD Theses available at http://etheses.bham.ac.uk/253/1/Tagg09PhD.pdf
16
+ - A subset of 3,375 SMS ham messages of the NUS SMS Corpus (NSC), which is a corpus of about 10,000 legitimate messages collected for research at the Department of Computer Science at the National University of Singapore. The messages largely originate from Singaporeans and mostly from students attending the University. These messages were collected from volunteers who were made aware that their contributions were going to be made publicly available. The NUS SMS Corpus is avalaible at: http://www.comp.nus.edu.sg/~rpnlpir/downloads/corpora/smsCorpus/
17
+ - The amount of 1,002 SMS ham messages and 322 spam messages extracted from the SMS Spam Corpus v.0.1 Big created by Jos� Mar�a G�mez Hidalgo and public available at: http://www.esp.uem.es/jmgomez/smsspamcorpus/
18
+
19
+
20
+ 1.2. Statistics
21
+ ---------------
22
+
23
+ There is one collection:
24
+
25
+ - The SMS Spam Collection v.1 (text file: smsspamcollection) has a total of 4,827 SMS legitimate messages (86.6%) and a total of 747 (13.4%) spam messages.
26
+
27
+
28
+ 1.3. Format
29
+ -----------
30
+
31
+ The files contain one message per line. Each line is composed by two columns: one with label (ham or spam) and other with the raw text. Here are some examples:
32
+
33
+ ham What you doing?how are you?
34
+ ham Ok lar... Joking wif u oni...
35
+ ham dun say so early hor... U c already then say...
36
+ ham MY NO. IN LUTON 0125698789 RING ME IF UR AROUND! H*
37
+ ham Siva is in hostel aha:-.
38
+ ham Cos i was out shopping wif darren jus now n i called him 2 ask wat present he wan lor. Then he started guessing who i was wif n he finally guessed darren lor.
39
+ spam FreeMsg: Txt: CALL to No: 86888 & claim your reward of 3 hours talk time to use from your phone now! ubscribe6GBP/ mnth inc 3hrs 16 stop?txtStop
40
+ spam Sunshine Quiz! Win a super Sony DVD recorder if you canname the capital of Australia? Text MQUIZ to 82277. B
41
+ spam URGENT! Your Mobile No 07808726822 was awarded a L2,000 Bonus Caller Prize on 02/09/03! This is our 2nd attempt to contact YOU! Call 0871-872-9758 BOX95QU
42
+
43
+ Note: messages are not chronologically sorted.
44
+
45
+
46
+ 2. USAGE
47
+ --------
48
+
49
+ We offer a comprehensive study of this corpus in the following paper that is under review. This work presents a number of statistics, studies and baseline results for several machine learning methods.
50
+
51
+ [1] Almeida, T.A., G�mez Hidalgo, J.M., Yamakami, A. Contributions to the study of SMS Spam Filtering: New Collection and Results. Proceedings of the 2011 ACM Symposium on Document Engineering (ACM DOCENG'11), Mountain View, CA, USA, 2011. (Under review)
52
+
53
+
54
+ 3. ABOUT
55
+ --------
56
+
57
+ The corpus has been collected by Tiago Agostinho de Almeida (http://www.dt.fee.unicamp.br/~tiago) and Jos� Mar�a G�mez Hidalgo (http://www.esp.uem.es/jmgomez).
58
+
59
+ We would like to thank Dr. Min-Yen Kan (http://www.comp.nus.edu.sg/~kanmy/) and his team for making the NUS SMS Corpus available. See: http://www.comp.nus.edu.sg/~rpnlpir/downloads/corpora/smsCorpus/. He is currently collecting a bigger SMS corpus at: http://wing.comp.nus.edu.sg:8080/SMSCorpus/
60
+
61
+ 4. LICENSE/DISCLAIMER
62
+ ---------------------
63
+
64
+ We would appreciate if:
65
+
66
+ - In case you find this corpus useful, please make a reference to previous paper and the web page: http://www.dt.fee.unicamp.br/~tiago/smsspamcollection/ in your papers, research, etc.
67
+ - Send us a message to [email protected] in case you make use of the corpus.
68
+
69
+ The SMS Spam Collection v.1 is provided for free and with no limitations excepting:
70
+
71
+ 1. Tiago Agostinho de Almeida and Jos� Mar�a G�mez Hidalgo hold the copyrigth (c) for the SMS Spam Collection v.1.
72
+
73
+ 2. No Warranty/Use At Your Risk. THE CORPUS IS MADE AT NO CHARGE. ACCORDINGLY, THE CORPUS IS PROVIDED `AS IS,' WITHOUT WARRANTY OF ANY KIND, INCLUDING WITHOUT LIMITATION THE WARRANTIES THAT THEY ARE MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. YOU ARE SOLELY RESPONSIBLE FOR YOUR USE, DISTRIBUTION, MODIFICATION, REPRODUCTION AND PUBLICATION OF THE CORPUS AND ANY DERIVATIVE WORKS THEREOF BY YOU AND ANY OF YOUR SUBLICENSEES (COLLECTIVELY, `YOUR CORPUS USE'). THE ENTIRE RISK AS TO YOUR CORPUS USE IS BORNE BY YOU. YOU AGREE TO INDEMNIFY AND HOLD THE COPYRIGHT HOLDERS, AND THEIR AFFILIATES HARMLESS FROM ANY CLAIMS ARISING FROM OR RELATING TO YOUR CORPUS USE.
74
+
75
+ 3. Limitation of Liability. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR THEIR AFFILIATES, OR THE CORPUS CONTRIBUTING EDITORS, BE LIABLE FOR ANY INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES, INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES, EVEN IF ADVISED OF THE POSSIBILITY THEREOF, AND REGARDLESS OF WHETHER ANY CLAIM IS BASED UPON ANY CONTRACT, TORT OR OTHER LEGAL OR EQUITABLE THEORY, RELATING OR ARISING FROM THE CORPUS, YOUR CORPUS USE OR THIS LICENSE AGREEMENT.