ium_444018/lab2/main.py

55 lines
1.8 KiB
Python

import numpy as np
import pandas as pd
from sklearn.model_selection import train_test_split
def drop_relevant_columns():
imbd_data.drop(columns=["Poster_Link"], inplace=True)
imbd_data.drop(columns=["Overview"], inplace=True)
def lowercase_columns_names():
imbd_data["Series_Title"] = imbd_data["Series_Title"].str.lower()
imbd_data["Genre"] = imbd_data["Genre"].str.lower()
imbd_data["Director"] = imbd_data["Director"].str.lower()
imbd_data["Star1"] = imbd_data["Star1"].str.lower()
imbd_data["Star2"] = imbd_data["Star2"].str.lower()
imbd_data["Star3"] = imbd_data["Star3"].str.lower()
imbd_data["Star4"] = imbd_data["Star4"].str.lower()
def gross_to_numeric():
global imbd_data
imbd_data = imbd_data.replace(np.nan, '', regex=True)
imbd_data["Gross"] = imbd_data["Gross"].str.replace(',', '')
imbd_data["Gross"] = pd.to_numeric(imbd_data["Gross"], errors='coerce')
def create_train_dev_test():
data_train, data_test = train_test_split(imbd_data, test_size=230, random_state=1)
data_test, data_dev = train_test_split(data_test, test_size=115, random_state=1)
print("Dataset successfully divided into test/dev/train sets\n")
data_test.to_csv("data_test.csv", encoding="utf-8", index=False)
data_dev.to_csv("data_dev.csv", encoding="utf-8", index=False)
data_train.to_csv("data_train.csv", encoding="utf-8", index=False)
print("Data train description: ")
print(data_train.describe(include="all"))
print("\nData test description: ")
print(data_test.describe(include="all"))
print("\nData dev description: ")
print(data_dev.describe(include="all"))
imbd_data = pd.read_csv('imdb_top_1000.csv')
drop_relevant_columns()
lowercase_columns_names()
imbd_data = imbd_data.dropna()
gross_to_numeric()
create_train_dev_test()