示例#1
0
 def create(self, validated_data):
     company = Company()
     company.name = validated_data.get('name', 'default name')
     company.description = validated_data.get('description',
                                              'default description')
     company.save()
     return company
示例#2
0
def add_company_save(request):
    """
    This method is for adding a new company

    Extended description of function.
    arg(request)

    """
    if request.method != "POST":
        return HttpResponse("Method Not Allowed")
    else:
        company_name = request.POST.get("company_name")
        logo = request.FILES.get("logo")
        email = request.POST.get("email")
        website = request.POST.get("website")
        try:
            company_model = Company(name=company_name,
                                    email=email,
                                    website=website,
                                    logo=logo)
            company_model.save()
            messages.success(request, "Successfully Added A Company")
            return HttpResponseRedirect(reverse("add_company"))
        except:

            messages.error(request, "Failed to Add A Company")
            return HttpResponseRedirect(reverse("add_company"))
示例#3
0
    def create(self, validated_data):
        company = Company()
        company.name = validated_data.get('name')
        company.description = validated_data.get('description')
        company.city = validated_data.get('city')
        company.address = validated_data.get('address')

        company.save()
        return company
示例#4
0
def create_entry(company_data, user_data):
    from api.models import Company, User

    try:
        company = Company(**company_data)
        company.save()

        user = User(**dict(company_id=company.id, **user_data))
        user.save()
    except Exception as e:
        print(e)
        pass
示例#5
0
    def import_companies(self):
        csv_file = self.read_file('importer/data/companies.csv')

        print 'Importing Companies...'
        for row in csv_file:
            try:
                Company.objects.get(name=row[0])
                print 'Company', row[0], 'already registered.'
            except ObjectDoesNotExist:
                company = Company()
                company.name = row[0]
                company.save()
示例#6
0
def company(request):
    if request.method == 'GET':
        ticker = request.GET.get('ticker')
        name = Company.objects.get(ticker=ticker).name
        return HttpResponse('GET success: ' + ticker + ' ' + name)
    elif request.method == 'PUT':
        ticker = request.GET.get('ticker')
        name = request.GET.get('name')
        print(ticker, name)
        c = Company(ticker=ticker, name=name)
        c.save()
        return HttpResponse("PUT success: " + ticker + ' ' + name)
示例#7
0
class CompanyModelTestCase(TestCase):
    """This class defines the test suite for the Company model."""
    def setUp(self):
        """Define the test client and other test variables."""
        self.company_name = ""
        self.company = Company(name=self.company_name)

    def test_model_can_create_a_company(self):
        """Test the company model can create a company."""
        old_count = Company.objects.count()
        self.company.save()
        new_count = Company.objects.count()
        self.assertNotEqual(old_count, new_count)
示例#8
0
 def create(self, validated_data):
     client_data = copy.deepcopy(validated_data)
     del client_data['contacts']
     contact_list_data = validated_data['contacts']
     company = Company(**client_data)
     company.save()
     for contact_data in contact_list_data:
         contact = Contact(**contact_data)
         contact.save()
         companycontact = CompanyContact()
         companycontact.company = company
         companycontact.contact = contact
         companycontact.save()
     return company
示例#9
0
def new_multiple_companies(app):
    companies = []
    for each in range(3):
        params = {'name': fake.company()}
        company = Company(**params)
        companies.append(company.save())
    return companies
示例#10
0
 def test_save(self, init_db):
     """Test for creating a new company
     
         Args:
             init_db(SQLAlchemy): fixture to initialize the test database
     """
     params = {'name': fake.company()}
     company = Company(**params)
     assert company == company.save()
示例#11
0
 def create(self, validated_data):
     company = Company(**validated_data)
     company.save()
     return company
示例#12
0
 def create(self, validated_data):
     # {'name': 'new category 4'}
     # name='new category 4'
     company = Company(**validated_data)
     company.save()
     return company
示例#13
0
 def create(self, validated_data):
     company = Company()
     company.name = validated_data.get('name')
     company.save()
     return company
示例#14
0
import os

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "backend.settings")
from django import setup

setup()

from api.models import Company

companies = [
    "トEタ自動車(株)",
    "ソフトパンクグループ(株)",
    "任天丼(株)",
    "ンニー(株)",
    "(株)NTTコドモ",
    "中内製薬(株)",
    "アマテラス製薬(株)",
    "丈田薬品工業(株)",
    "(株)目立製作所",
    "(株)木寸田製作所",
    "エヌスリー(株)",
    "往友商事(株)",
]

for company in companies:
    company = Company(name=company)
    company.save()
示例#15
0
def new_company(app):
    params = {
        'name': fake.company(),
    }
    company = Company(**params)
    return company.save()
示例#16
0
class LCRScrape:
    def __init__(self, cr_sub_id, gov):
        self.cr_sub_id = cr_sub_id
        self.governorate = gov
        self.cr_id = str(gov) + str(cr_sub_id).zfill(9)
        self.source_url = constants.COMMERCIAL_REGISTRY_URL + self.cr_id
        self.soup = None
        self.company = None
        self.personnel = {}

    def extract_data(self):
        self.__get_soup()
        self.__get_company()
        self.__get_personnel()

    def __get_soup(self):
        try:
            r = requests.get(self.source_url)
            self.soup = BeautifulSoup(r.content, 'html.parser')
        except Exception as e:
            scrape_error = ScrapeError(cr_id=self.cr_id,
                                       model_type='UK',
                                       error_message=str(e))
            scrape_error.save()
            raise Exception("Failed to get soup from source url")

    def __get_company(self):
        try:
            self.__scrape_company()
        except Exception as e:
            company_scrape_error = ScrapeError(cr_id=self.cr_id,
                                               model_type='CO',
                                               error_message=str(e))
            company_scrape_error.save()
            raise Exception("Failed to scrape company")

    def __get_personnel(self):
        if self.company.missing_personnel_data:
            return False
        try:
            self.__scrape_personnel()
        except Exception as e:
            personnel_scrape_error = ScrapeError(cr_id=self.cr_id,
                                                 model_type='PE',
                                                 error_message=str(e))
            personnel_scrape_error.save()
            raise Exception("Failed to scrape personnel table")

    def __scrape_company(self):
        """
        Scrapes company data from html elements
        Creates a Company object and saves to database
        """
        registration_date = self.__get_soup_value('DataList1_Label5_0')
        registration_date = datetime.strptime(registration_date,
                                              '%m/%d/%Y %I:%M:%S %p')
        registration_date = make_aware(registration_date)
        personnel_data = self.soup.find('tr', {'id': 'Relations_ListView_Tr1'})
        missing_personnel_data = False if personnel_data else True
        self.company = Company(
            cr_id=self.cr_id,
            cr_sub_id=self.cr_sub_id,
            source_url=self.source_url,
            registration_number=self.__get_soup_value('DataList1_Label1_0'),
            name=self.__get_soup_value('DataList1_Label2_0'),
            additional_name=self.__get_soup_value('DataList1_Label3_0'),
            governorate=self.governorate,
            registration_date=registration_date,
            record_type=self.__get_soup_value('DataList1_Label6_0'),
            company_status=self.__get_soup_value('DataList1_Label7_0'),
            company_duration=self.__get_soup_value('DataList1_Label8_0'),
            legal_form=self.__get_soup_value('DataList1_Label9_0'),
            capital=self.__get_soup_value('DataList1_Label10_0', 'decimal'),
            title=self.__get_soup_value('DataList1_Label11_0'),
            description=self.__get_soup_value('DataList1_Label12_0'),
            missing_personnel_data=missing_personnel_data)
        self.company.save()

    def __scrape_personnel(self):
        """
        Loops through personnel table on company website
            - Scrapes person data from html elements
            - If person has already been scraped
                - Update Person object to include extra relationship
            - Else
                - Create Person object and add to database
        """
        table_rows = self.soup.find('tr', {'id': 'Relations_ListView_Tr1'})
        table_rows = table_rows.parent.findAll('tr')
        table_rows = table_rows[1:]  # Ignore column names
        person_dict = {}
        for index, row in enumerate(table_rows):
            name = self.__get_soup_value('Relations_ListView_desigLabel_' +
                                         str(index))
            relationship = self.__get_soup_value(
                'Relations_ListView_relLabel_' + str(index))
            if name in person_dict.keys():
                person = person_dict[name]
                person = self.__update_person(person, relationship, index)

            else:
                person = Person(
                    name=name,
                    company_id=self.company.id,
                    nationality=self.__get_soup_value(
                        'Relations_ListView_countryLabel_' + str(index)),
                    relationship=relationship,
                    stock=self.__get_soup_value(
                        'Relations_ListView_a_valLabel_' + str(index), 'int'),
                    quota=self.__get_soup_value(
                        'Relations_ListView_s_valLabel_' + str(index), 'int'),
                    ratio=self.__get_soup_value(
                        'Relations_ListView_r_valLabel_' + str(index), 'int'))
                person_dict[name] = person
        self.personnel = person_dict.values()
        Person.objects.bulk_create(self.personnel)

    def __update_person(self, person, relationship, index):
        person.relationship = person.relationship + ' \\ ' + relationship
        stock = self.__get_soup_value(
            'Relations_ListView_a_valLabel_' + str(index), 'int')
        quota = self.__get_soup_value(
            'Relations_ListView_s_valLabel_' + str(index), 'int')
        ratio = self.__get_soup_value(
            'Relations_ListView_r_valLabel_' + str(index), 'int')
        if person.stock == 0:
            person.stock = stock
        if person.quota == 0:
            person.quota = quota
        if person.ratio == 0:
            person.ratio = ratio

    def __get_soup_value(self, tag_id, cast_type='string'):
        """ Helper for soup element casting """
        contents = self.soup.find('span', {'id': tag_id}).contents
        if contents:
            if cast_type == 'string':
                return str(contents[0])
            elif cast_type == 'decimal':
                return Decimal(contents[0])
            elif cast_type == 'int':
                return int(contents[0])
        else:
            return ''